/*!
 * Public SlideDeck JavaScript
 * 
 * All public JavaScript necessary for globally applicable SlideDeck features
 * 
 * @package SlideDeck
 * 
 * @author dtelepathy
 * @package SlideDeck
 * @since 2.0.0
 */

/*!
Copyright 2012 digital-telepathy  (email : support@digital-telepathy.com)

This file is part of SlideDeck.

SlideDeck is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.

SlideDeck is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU General Public License for more details.

You should have received a copy of the GNU General Public License
along with SlideDeck.  If not, see <http://www.gnu.org/licenses/>.
*/


// ----------------------------------------------------------
// A short snippet for detecting versions of IE in JavaScript
// without resorting to user-agent sniffing
// ----------------------------------------------------------
// If you're not in IE (or IE version is less than 5) then:
//     ie === undefined
// If you're in IE (>=5) then you can determine which version:
//     ie === 7; // IE7
// Thus, to detect IE:
//     if (ie) {}
// And to detect the version:
//     ie === 6 // IE6
//     ie > 7 // IE8, IE9 ...
//     ie < 9 // Anything less than IE9
// ----------------------------------------------------------
 
// UPDATE: Now using Live NodeList idea from @jdalton
 
var ie = (function(){
    var undef,
        v = 3,
        div = document.createElement('div'),
        all = div.getElementsByTagName('i');
    while (
        div.innerHTML = '<!--[if gt IE ' + (++v) + ']><i></i><![endif]-->',
        all[0]
    );
    return v > 4 ? v : undef;
}());


// SlideDeck Fading Navigation Class
var SlideDeckFadingNav = function(elem){
    this.elems = {};
    this.initialize(elem);
};
var SlideDeckPrefix = "sd2-";

// SlideDeck Video Deck Class
var SlideDeckVideoAPIs;
var __slideDeckVideos = {};
var __slideDeckVideosYTAPIReady = false;
var __slideDeckVideosDMAPIReady = false;

// SlideDeck LazyLoad Class
var SlideDeckLazyLoad = function(elem){
    this.elems = {};
    this.initialize(elem);
};

/**
 * Vertical SlideDeck Detection
 * 
 * This function takes a SlideDeck object and
 * tests the structure to determine if it has vertical slides.
 * This is used to tell the SlideDeckVideoAPIs class and listeners
 * that the traversal and indexing should be adjusted. 
 */
function __isVerticalDeck( slidedeck ){
    // If the HTML element is passed in, detect differently.
    if( typeof( slidedeck.deck === 'undefined' ) ) {
        if( jQuery(slidedeck).find('.slidesVertical').length > 0 ) {
            return true;
        }
        return false;
    }else{
        // Are there vertical slides anywhere on this deck?
        if(slidedeck.verticalSlides){
            // Does the vertical slides object exist for the slide we're going to?
            if(slidedeck.verticalSlides[slidedeck.current-1]){
                // Does the slide we're going to actually have vertical slides?
                if(slidedeck.verticalSlides[slidedeck.current-1].navChildren){
                    // Vertical
                    return true;
                }else{
                    // Horizontal
                    return false;
                }
            }
        }
    }
    return false;
}

/**
 * Is this an iOS browser?
 * 
 * @return boolean
 */
function __slidedeck2_isiOS(){
    var iOS = false;
    
    if(
        // If iOS
        navigator.userAgent.match(/like Mac OS X/i)
        // If iPad - Specifically
        || navigator.userAgent.match(/iPad/i)
    ) iOS = true;
    
    return iOS;
}

/**
 * Is this a mobile browser
 * 
 * @return boolean
 */
function __slidedeck2_isMobile(){
    var mobile = false;
    
    if(
        // If iOS
        navigator.userAgent.match(/like Mac OS X/i)
        // If iOS or Android
        || (navigator.userAgent.match(/android/i) || navigator.userAgent.match(/like Mac OS X/i))
        // If iPad - Specifically
        || navigator.userAgent.match(/iPad/i)
    ) mobile = true;
    
    return mobile;
}


/**
 * *****************************************
 * YouTube Setup Start
 * *****************************************
 */
function onYouTubePlayerAPIReady() {
    //console.log( "YouTube API Ready" );
    __slideDeckVideosYTAPIReady = true;
}


/**
 * *****************************************
 * Dailymotion Setup Start
 * *****************************************
 */
window.dmAsyncInit = function(){
    //console.log( "DailyMotion API Ready" );
    __slideDeckVideosDMAPIReady = true;
};


// Primary Overlay Class
var SlideDeckOverlay = function(elem){
    this.classes = {
        container: 'slidedeck-overlays',
        frame: 'slidedeck-frame',
        toggle: 'slidedeck-overlays-showhide',
        wrapper: 'slidedeck-overlays-wrapper',
        overlay: 'slidedeck-overlay',
        flipper: 'slidedeck-overlay-flipper'
    };
    
    // Elements used by this Class
    this.elems = {};
    
    // Speed of individual animations
    this.speed = 200;
    
    // Easing
    this.easing = "ease-in-out";
    
    this.initialize(elem);
};
// Extensible Overlay processing object, key all functions by their type
var SlideDeckOverlays = {
    // Click event actions
    actions: {},
    // Initialization and setup actions
    inits: {}
};

function briBriFlex(elem, max){
    var $elem = jQuery(elem);
    
    $elem.append('<span class="test-character" style="position:absolute;display:block;top:0;left:-999em;">M</span>');
    var testChar = $elem.find('.test-character');
    
    var tHeight = $elem.outerHeight();
    var mHeight = testChar.outerHeight();
    var loopCount = 0;
    
    var fontSize = parseInt($elem.css('font-size'), 10);
    var lineHeight = parseInt($elem.css('line-height'), 10);
    
    if( tHeight > mHeight*max ){
        $elem.css('line-height', 'auto');
    }
    
    while ( tHeight > mHeight*max ) {
        fontSize--;
        lineHeight--;
        
        $elem.css('font-size', fontSize + 'px');
        loopCount++;
        
        mHeight = testChar.outerHeight();
        tHeight = $elem.outerHeight();
    }
    
    if(loopCount){
        $elem.css('line-height', lineHeight + 'px');
    }
    
    testChar.remove();
}

(function($){
    $.extend($.fn, {
        isMobile: function(){
            return false;
        }
    });
    
    window.SlideDeckVideoAPIs = function( slidedeck ){
        var self = this;
        
        var autoStartNextVideo = true;
        var autoResumePlayback = true;
        var advanceAtVideoEnd = true;
        // If iOS
        if (navigator.userAgent.match(/like Mac OS X/i)) {
            // Auto Starting of the next video is buggy on iOS.
            autoStartNextVideo = false;
        }
        // If iOS or Android
        if (navigator.userAgent.match(/android/i) || navigator.userAgent.match(/like Mac OS X/i)) {
            // Auto resuming the playback on slide navigation:
            // this can be troublesome due to the native "pop-out" player.
            autoResumePlayback = false;
        }
        // If iPad - Specifically
        if (navigator.userAgent.match(/iPad/i)) {
            // This is OK on the iPad as there's no "pop-out" player.
            autoResumePlayback = true;
        }
        
        var youTubeAPIRetryCounter = 0;
        var DailyMotionAPIRetryCounter = 0;
        var slidedeck = $(slidedeck);
        var slidedeckFrame = slidedeck.closest('.slidedeck-frame');
        var deck = slidedeck.slidedeck();
        var verticalDeck;
        var deckElement = slidedeck;
        
        // Position Click to Play Button
        var playButtons = deckElement.find('.cover .play');
        for (var i=0; i < playButtons.length; i++) {
            var thisButton = $(playButtons[i]);
            thisButton.css({
                  marginTop: Math.round( thisButton.outerHeight() / 2 ) * -1,
                  marginLeft: Math.round( thisButton.outerWidth() / 2 ) * -1
            });
            
            // Only for IE - detect background image url and update style for DD element
            if( ie <= 8.0 ){
                var cover = thisButton.parents('.cover');
                if( cover.css('background-image') != 'none' ){
                    var imgurl = cover.css('background-image').match( /url\([\"\'](.*)[\"\']\)/ )[1];
                    cover.css({
                        background: 'none'
                    });
                    cover.append('<div class="ie-background-image"></div>');
                    var ieCover = cover.find('.ie-background-image');
                    ieCover[0].style.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(src='" + imgurl + "', sizingMethod='scale')";
                }
            }
        }
        
        // Click cover to play
        deckElement.find('.cover .play').click(function(event){
            event.preventDefault();
            
            var cover = $(this).parent();
            var deckId = deckElement[0].id;
            
            var videoContainerID = '';            
            if( cover.prev('.video-container').data('video-id') ){
                videoContainerID = cover.prev('.video-container').data('video-id');
            }else{
                videoContainerID = cover.prev('.video-container').attr('id').split('__')[1];
            }
            var slidedeck = deckElement.slidedeck();
            var slides = slidedeck.slides;
            
            /**
             * If the deck is a vertical deck, then we need to reset the slides array.
             * Typically this is the horizontal set of slides but in this case it's the vertical
             * slides instead.
             */
            if( __isVerticalDeck( deckElement ) ){
                slides = slidedeck.vertical().slides;
            }
            
            var videoIndex = slides.index( jQuery( '[id*="video__' + videoContainerID + '"]' ).closest('dd') );
            var playerType = slides.eq(videoIndex).find('.video-container')[0].className.split(' ')[0];
            
            cover.fadeOut();
            deck.pauseAutoPlay = true;
            playVideo( ( videoIndex + 1 ), playerType, deckId );
        });
        
        deckElement.find('.cover .play-video-alternative').click(function(event){
            event.preventDefault();
            $(this).closest('.cover').find('.play').trigger('click');
        });
        
        // Get the old complete and before options
        var deckOptions = deck.options;
        var oldBefore = deck.options.before;
        var oldComplete = deck.options.complete;
        var deckContext = deck;
        var isVertical = false;
        if( __isVerticalDeck( deck.deck ) ){
            isVertical = true;
            deckContext = deck.vertical();
            deckOptions = deck.vertical().options;
            oldBefore = deckOptions.before;
            oldComplete = deckOptions.complete;
        }
        
        deckOptions.before = function(deck){
            // If the old before option was a function, run it
            if(typeof(oldBefore) == 'function')
                oldBefore(deck);
            
            if(typeof(deck.deck) != 'undefined'){
                var slidedeckElem = deck.deck[0];
            } else {
                var slidedeckElem = deck.slides.closest('.slidedeck')[0];
            }
            
            // Pause ALL THE videos!
            jQuery.data( slidedeckElem, 'video-slidedeck' ).slideDeckPauseAllVideos(deck);
        };
        
        deckOptions.complete = function(deck){
            // If the old complete option was a function, run it
            if(typeof(oldComplete) == 'function')
                oldComplete(deck);
            
            var current = deckContext.current;
            if( isVertical )
                current += 1;
            
            var $videoContainer = deckContext.slides.eq(current - 1).find('.video-container');
            if($videoContainer.length){
                var playerType = $videoContainer[0].className.split(' ')[0];
                
                // Resume the video being shown
                if( autoResumePlayback ){
                    playVideoIfPaused( ( current - 1 ), playerType );
                }
            }
        };
        
        /**
         * Play Video if Paused
         * 
         * Checks to see if the video is indeed paused 
         * (using a few different methods) and if it in indeed
         * paused, it will resume playback.
         */
        function playVideoIfPaused( index, playerType ){
            var videoPlayingClass = 'sd2-video-playing';
            var videosDeckElement = __slideDeckVideos[ deckElement[0].id ];

            // Return if the video isn't there yet
            if( typeof(videosDeckElement) === 'undefined' ) { return false; }

            // Fetch the player using the slide index.
            var player = videosDeckElement[ "v" + index ];
            
            switch( playerType ){
                case 'youtube':
                    if( typeof( player ) != 'undefined' ){
                        // So... this is only something that we want to do if the video isn't ended or
                        // if the video isn't started. Vimeo (below) has a method to unload. YouTube does not.
                        if( typeof( player.getDuration ) == 'function' ){
                            var totalTime = player.getDuration();
                            var currentTime = player.getCurrentTime();
                            if( ( player.getCurrentTime() > 0 ) && ( totalTime != currentTime ) ){
                                player.playVideo();
                                slidedeckFrame.addClass( videoPlayingClass );
                            }
                        }
                    }
                break;
                case 'vimeo':
                    if( typeof( player ) != 'undefined' ){
                        // It seems that the API functions that return a value need to do so via a
                        // callback function... alright... I'll play along.
                        if( typeof( player.api ) == 'function' ){
                            player.api('getCurrentTime', function (value, player_id) {
                                var currentTime = value;
                                if( currentTime > 0 ){
                                    player.api('play');
                                    slidedeckFrame.addClass( videoPlayingClass );
                                }
                            });
                        }
                    }
                break;
                case 'dailymotion':
                    if( typeof( player ) != 'undefined' ){
                        // For the dailymotion case, we'll subtract a second from the video's end.
                        // This is because the video can sometimes end just before the duration time defined.
                        if( ( player.currentTime > 0 ) && ( player.currentTime < ( player.duration - 1 ) ) ){
                            player.play();
                            slidedeckFrame.addClass( videoPlayingClass );
                        }
                    }
                break;
            }
        }
        
        function playVideo( index, playerType, deckId ){
            var deckElement = $( '#' + deckId );
            var videosDeckElement = __slideDeckVideos[ deckElement[0].id ];

            // Return if the video isn't there yet
            if( typeof(videosDeckElement) === 'undefined' ) { return false; }

            var player = videosDeckElement[ "v" + (index - 1) ];

            if( typeof( player ) != 'undefined' ){
                switch( playerType ){
                    case 'youtube':
                        if( typeof( player.playVideo ) == 'function' ){
                            player.playVideo();
                        }
                    break;
                    case 'vimeo':
                        if( typeof( player.api ) == 'function' ){
                            player.api('play');
                        }
                    break;
                    case 'dailymotion':
                        if( typeof( player.play ) == 'function' ){
                            player.play();
                        }
                    break;
                }
                // Add a video playing class to the deck
                slidedeckFrame.addClass('sd2-video-playing');
            }
        }
                    
        function videoSeekTo( index, playerType, seconds ){
            var player = __slideDeckVideos[ deckElement[0].id ][ "v" + index ];
            switch( playerType ){
                case 'youtube':
                    if( typeof( player ) != 'undefined' ){
                        player.seekTo( seconds );
                    }
                break;
                case 'vimeo':
                    if( typeof( player ) != 'undefined' ){
                        player.api( 'seekTo', seconds );
                    }
                break;
                case 'dailymotion':
                    if( typeof( player ) != 'undefined' ){
                        player.seek( seconds );
                    }
                break;
            }
        }
        
        /**
         * Here's the function that we call when a playing video ends.
         * 
         * It's called by all three (at the time of this writing) APIs and 
         * will offer to advance the slide and potentially play the next video.
         */
        this.videoEnded = function( index, playerType, deckId ){
            var deckElement = $( '#' + deckId );
            var player = __slideDeckVideos[ deckId ][ "v" + index ];
            
            switch( playerType ){
                case 'youtube':
                    // Hmmmm...
                break;
                case 'vimeo':
                    if( typeof( player != 'undefined' ) ){
                        player.api('unload');
                    }
                break;
                case 'dailymotion':
                    if( typeof( player != 'undefined' ) ){
                        // Hmmmm...
                    }
                break;
            }
            // The above Hmmmms are because I can't find a reliable way to unload/reset the video's
            // playback state for YouTube and Dailymotion.
            
            if( advanceAtVideoEnd ){
                // If the deck is vertical, we need to make a few adjustments.
                var deckContext = deckElement.slidedeck();
                if( __isVerticalDeck( deckElement ) )
                    deckContext = deckContext.vertical();
                
                // Move to the next slide if the option is true.
                deckContext.next(function(){
                    var current = deckContext.current;
                    var currentSlide = $( '#' + deckId ).find('dd:eq(' + ( current - 1 ) + ')');
                    
                    // More vertical accommodations.
                    if( __isVerticalDeck( deckElement ) ){
                        current += 1;
                        currentSlide = $( '#' + deckId ).find('.slidesVertical dd:eq(' + ( current - 1 ) + ')');
                    }
                    
                    var playerType = deckElement.find('dd .video-container:eq(' + ( current - 1 ) + ')')[0].className.split(' ')[0];
                    // Start playing the video on the destination slide if the
                    // option is true. Note: iOS and Android produce bad UX when 
                    // this option is set to true. It's being overriden above.
                    if( autoStartNextVideo ){
                        currentSlide.find('a.play-video-button').parents('dd').addClass('sd2-hide-slide-content');
                        currentSlide.find('a.play-video-button').click();
                    }
                });
            }
        };
        
        // Pauses all the active players in the deck,
        // switches by video player type.
        // Pause ALL THE Players!
        this.slideDeckPauseAllVideos = function(thedeck) {
            if(thedeck.deck){
                var deckId = thedeck.deck.attr('id');
            } else {
                var deckId = thedeck.slides.closest('.slidedeck').attr('id');
            }
            var players = __slideDeckVideos[deckId];
            
            for( var k in players ){
                var player = players[ k ];
                
                // Remove the video playing class from the deck
                slidedeckFrame.removeClass('sd2-video-playing');
                
                // Different commands for different videos.
                switch( player.playerType ){
                    case 'youtube':
                        if( typeof( player.getPlayerState ) == 'function' ){
                            // For YouTube, we'll check the player state before pausing.
                            // This is important because we depend on the player state elsewhere;
                            // we don't want to erroneously set the state to paused.
                            if( player.getPlayerState() == 1 ){
                                player.pauseVideo();
                            }
                        }
                    break;
                    case 'vimeo':
                        // We removed a conditional here that seemed to be superfluous.
                        player.api('pause');
                    break;
                    case 'dailymotion':
                        // Here we're checking the paused property even though
                        // it is not documented.
                        if( !player.paused ){
                            player.pause();
                        }
                    break;
                }          
            }
        };

        this.loadYouTubeVideo = function(deckElement, slideIndex){
            var self = this;

            deckElement = jQuery(deckElement);
            var deckId = deckElement.attr('id');
            var videoContainer = deckElement.find('dd.slide:eq(' + ( slideIndex ) + ') .video-container.youtube');

            // If this is a vertical deck, then we need to source the slides differently
            if( __isVerticalDeck(deckElement) ){
                videoContainer = deckElement.find('dl.slidesVertical dd:eq(' + ( slideIndex ) + ') .video-container.youtube');
            }
            
            var videoContainerID = jQuery(videoContainer).attr('id');
            var videoID = '';

            // Exit if there's no relevant container here.
            if( typeof(videoContainerID) === 'undefined' ) { return false; }
            
            // Legacy support for the video ID format switch
            if( jQuery(videoContainer).data('video-id') ){
                videoID = jQuery(videoContainer).data('video-id');
            }else{
                videoID = videoContainerID.split('__')[1];
            }

            // If the APi is not ready, we'll wait until it is
            // However, we will only try a maxiumum of 30 times.
            if( __slideDeckVideosYTAPIReady === false ) {
                //console.log( "Can't load YouTube API yet, trying again..." );
                if( youTubeAPIRetryCounter < 30 ) {
                    setTimeout(function(){
                        self.loadYouTubeVideo(deckElement, slideIndex);
                    }, 750);
                    youTubeAPIRetryCounter++;
                }
                return false;
            }

            var iFrameYouTubePlayer = new YT.Player( videoContainerID, {
                height: '100%',
                width: '100%',
                videoId: videoID,
                playerVars: {
                    'wmode': 'opaque',
                    'showinfo': 0,
                    'autohide': 1,
                    'rel': 0,
                    'disablekb': 1,
                    'cc_load_policy': 0,
                    'iv_load_policy': 3,
                    'modestbranding': 1,
                    'fs': 1
                }
            });
            
            jQuery( '#' + videoContainerID ).attr( 'webkitallowfullscreen', true );
            jQuery( '#' + videoContainerID ).attr( 'mozallowfullscreen', true );
            
            // Note the ternary statemnent at the end that handles a vertical deck by adding an offset:
            var videoIndex = deckElement.find('dd').index( jQuery( '#' + videoContainerID ).parents('dd') ) - ( __isVerticalDeck( deckElement ) ? 1 : 0 );
            
            iFrameYouTubePlayer.playerType = 'youtube';
            iFrameYouTubePlayer.addEventListener("onStateChange", function(video){
                switch( video.data ){
                    case 0:
                        // Video Ended...
                        jQuery.data( deckElement[0], 'video-slidedeck' ).videoEnded( videoIndex, 'youtube', deckId );
                    break;
                    case 1:
                        // Add the video playing class to the deck if a YouTube video is playing.
                        jQuery(deckElement[0]).parents('.slidedeck-frame').addClass("sd2-video-playing");
                        // Pause Autoplay on the SlideDeck when the video API says it's playing.
                        jQuery(deckElement[0]).slidedeck().pauseAutoPlay = true;
                    break;
                }
                iFrameYouTubePlayer.youTubePlayerState = video.data;
            });
            
            // Push the players into their global space.
            if( typeof( __slideDeckVideos[ deckElement.attr('id') ] ) != 'object' ){
                __slideDeckVideos[ deckElement.attr('id') ] = {};
            }
            __slideDeckVideos[ deckElement.attr('id') ][ "v" + videoIndex ] = iFrameYouTubePlayer;
        }; // loadYouTubeVideo

        this.loadVimeoVideo = function(deckElement, slideIndex){
            var self = this;

            deckElement = jQuery(deckElement);
            var deckId = deckElement.attr('id');
            var videoContainer = deckElement.find('dd.slide:eq(' + ( slideIndex ) + ') .video-container.vimeo');
            var slides = deckElement.slidedeck().slides;

            // If this is a vertical deck, then we need to source the slides differently
            if( __isVerticalDeck(deckElement) ){
                videoContainer = deckElement.find('dl.slidesVertical dd:eq(' + ( slideIndex ) + ') .video-container.vimeo');
                slides = deckElement.slidedeck().vertical().slides;
            }
            
            var videoContainerID = jQuery(videoContainer).attr('id');
            var videoID = '';

            // Exit if there's no relevant container here.
            if( typeof(videoContainerID) === 'undefined' ) { return false; }
            
            // Legacy support for the video ID format switch
            if( jQuery(videoContainer).data('video-id') ){
                videoID = jQuery(videoContainer).data('video-id');
            }else{
                videoID = videoContainerID.split('__')[1];
            }
            
            jQuery(videoContainer).append( '<iframe id="vimeoiFrame-' + videoContainerID + '" src="http://player.vimeo.com/video/' + videoID + '?api=1&byline=0&title=0&portrait=0&player_id=vimeoiFrame-' + videoContainerID + '" width="100%" height="100%" frameborder="0"></iframe>' );
            
            var videoIndex = slides.index( jQuery( '#' + videoContainerID ).closest('dd') );
            
            var iFrame = document.getElementById( 'vimeoiFrame-' + videoContainerID );
            var vimeoPlayer = $f( iFrame ).addEvent( 'ready', function(player_id) {
                var froogaloop = $f( player_id );
                // Listen for the Finished event
                froogaloop.addEvent('finish', function(data) {
                    jQuery.data( deckElement[0], 'video-slidedeck' ).videoEnded( videoIndex, 'vimeo', deckElement.attr('id') );
                });
                
                // Add the video playing class to the deck if a Vimeo video is playing.
                froogaloop.addEvent('play', function(data) {
                    jQuery(deckElement[0]).parents('.slidedeck-frame').addClass("sd2-video-playing");
                    // Pause Autoplay on the SlideDeck when the video API says it's playing.
                    jQuery(deckElement[0]).slidedeck().pauseAutoPlay = true;
                });
            });
            vimeoPlayer.playerType = 'vimeo';

            // Push the players into their global space.                
            if( typeof( __slideDeckVideos[ deckElement.attr('id') ] ) != 'object' ){
                __slideDeckVideos[ deckElement.attr('id') ] = {};
            }
            __slideDeckVideos[ deckElement.attr('id') ][ "v" + videoIndex ] = vimeoPlayer;
        }; // loadVimeoVideo
      
        this.loadDailyMotionVideo = function(deckElement, slideIndex){
            var self = this;

            deckElement = jQuery(deckElement);
            var deckId = deckElement.attr('id');
            var videoContainer = deckElement.find('dd.slide:eq(' + ( slideIndex ) + ') .video-container.dailymotion');
            var slides = deckElement.slidedeck().slides;

            // If this is a vertical deck, then we need to source the slides differently
            if( __isVerticalDeck(deckElement) ){
                videoContainer = deckElement.find('dl.slidesVertical dd:eq(' + ( slideIndex ) + ') .video-container.dailymotion');
                slides = deckElement.slidedeck().vertical().slides;
            }

            videoContainer.append('<div class="video-player-dm"></div>');

            var videoContainerID = videoContainer.attr('id');
            var videoID = '';

            // Exit if there's no relevant container here.
            if( typeof(videoContainerID) === 'undefined' ) { return false; }
            
            // Legacy support for the video ID format switch
            if( jQuery(videoContainer).data('video-id') ){
                videoID = jQuery(videoContainer).data('video-id');
            }else{
                videoID = videoContainerID.split('__')[1];
            }

            // If the APi is not ready, we'll wait until it is
            // However, we will only try a maxiumum of 30 times.
            if( __slideDeckVideosDMAPIReady === false ) {
                //console.log( "Can't load Dailymotion API yet, trying again..." );
                if( DailyMotionAPIRetryCounter < 30 ) {
                    setTimeout(function(){
                        self.loadDailyMotionVideo(deckElement, slideIndex);
                    }, 750);
                    DailyMotionAPIRetryCounter++;
                }
                return false;
            }

            // Note the ternary statemnent at the end that handles a vertical deck by adding an offset:
            var videoIndex = deckElement.find('dd').index( jQuery( '#' + videoContainerID ).parents('dd') ) - ( __isVerticalDeck( deckElement ) ? 1 : 0 );
            
            var dailymotionPlayer = DM.player( videoContainer[0], {
                video: videoID, 
                width: '100%', 
                height: '100%', 
                params: {}
            });
            
            // Store the player type for later use.
            dailymotionPlayer.playerType = 'dailymotion';
            
            // Attach some events on the player (using standard DOM events)
            dailymotionPlayer.addEventListener("ended", function(e){
                jQuery.data( deckElement[0], 'video-slidedeck' ).videoEnded( videoIndex, dailymotionPlayer.playerType, deckId );
            });
            
            // Add the video playing class to the deck if a Dailymotion video is playing.
            dailymotionPlayer.addEventListener("playing", function(e){
                jQuery(deckElement[0]).parents('.slidedeck-frame').addClass("sd2-video-playing");
                // Pause Autoplay on the SlideDeck when the video API says it's playing.
                jQuery(deckElement[0]).slidedeck().pauseAutoPlay = true;
            });
            
            // Push the players into their global space.                
            if( typeof( __slideDeckVideos[ deckElement.attr('id') ] ) != 'object' ){
                __slideDeckVideos[ deckElement.attr('id') ] = {};
            }
            __slideDeckVideos[ deckElement.attr('id') ][ "v" + videoIndex ] = dailymotionPlayer;
        }; // loadDailyMotionVideo

        return true;
    };
    
    SlideDeckFadingNav.prototype.nav = function(direction){
        this.slidedeck.pauseAutoPlay = true;
        
        switch(direction){
            case "next-horizontal":
                this.slidedeck.next();
            break;
            
            case "prev-horizontal":
                this.slidedeck.prev();
            break;
            
            case "next-vertical":
                if(this.slidedeck.options.cycle && this.slidedeck.vertical().current == this.slidedeck.vertical().slides.length - 1){
                    this.slidedeck.vertical().goTo(0);
                } else {
                    this.slidedeck.vertical().next();
                }
            break;
            
            case "prev-vertical":
                if(this.slidedeck.options.cycle && this.slidedeck.vertical().current == 0){
                    this.slidedeck.vertical().goTo(this.slidedeck.vertical().slides.length);
                } else {
                    this.slidedeck.vertical().prev();
                }
            break;
        }
    };
    
    SlideDeckFadingNav.prototype.checkVertical = function(slidedeck){
        // When being run as a before() action
        if(typeof(slidedeck) == 'undefined'){
            var slidedeck = this.slidedeck,
                frame = this.elems.frame,
                prevButton = this.elems.previousVertical,
                nextButton = this.elems.nextVertical;
        }
        // When being called independently from the prototype, use the passed in SlideDeck object
        else {
            var frame = slidedeck.deck.closest('.slidedeck-frame');
            var prevButton = frame.find('.deck-navigation.vertical.prev');
            var nextButton = frame.find('.deck-navigation.vertical.next');
        }
        
        frame.addClass('no-vertical-slide');
        
        // Are there vertical slides anywhere on this deck?
        if(slidedeck.verticalSlides){
            // Does the vertical slides object exist for the slide we're going to?
            if(slidedeck.verticalSlides[slidedeck.current-1]){
                // Does the slide we're going to actually have vertical slides?
                if(slidedeck.verticalSlides[slidedeck.current-1].navChildren){
                    frame.removeClass('no-vertical-slide');
                }
            }
        }
        
        // Do nothing if no vertical slides
        if(frame.hasClass('no-vertical-slide')){
            return false;
        }
        
        // Start with everything showed by default
        prevButton.show();
        nextButton.show();
    
        // Don't hide anything if cycle is turned on
        if(slidedeck.options.cycle){
            return false;
        }
        
        if(typeof(slidedeck.vertical()) != 'undefined'){
            // Last slide, hide next button
            if(slidedeck.vertical().current == slidedeck.vertical().slides.length - 1 && !frame.hasClass(SlideDeckPrefix + 'show-back-cover')){
                nextButton.hide();
            }
            // First slide, hide previous button
            else if(slidedeck.vertical().current == 0){
                prevButton.hide();
            }
        }
    };
    
    SlideDeckFadingNav.prototype.checkHorizontal = function(slidedeck){
        // When being run as a before() action
        if(typeof(slidedeck) == 'undefined'){
            var slidedeck = this.slidedeck,
                frame = this.elems.frame,
                prevButton = this.elems.previousHorizontal,
                nextButton = this.elems.nextHorizontal;
        }
        // When being called independently from the prototype, use the passed in SlideDeck object
        else {
            var frame = slidedeck.deck.closest('.slidedeck-frame');
            var prevButton = frame.find('.deck-navigation.horizontal.prev');
            var nextButton = frame.find('.deck-navigation.horizontal.next');
        }
        
        // Do nothing if vertical slides
        if(!frame.hasClass('no-vertical-slide')){
            return false;
        }
        
        // Start with everything showed by default
        prevButton.show();
        nextButton.show();
        
        // Don't hide anything if cycle is turned on
        if(slidedeck.options.cycle){
            return false;
        }
        
        // Last slide, hide next button
        if(slidedeck.current == slidedeck.slides.length && !frame.hasClass(SlideDeckPrefix + 'show-back-cover')){
            nextButton.hide();
        }
        // First slide, hide previous button
        else if(slidedeck.current == 1){
            prevButton.hide();
        }
    };
    
    // SlideDeckOverlay Class initialization
    SlideDeckFadingNav.prototype.initialize = function(elem){
        var self = this;
        
        this.elems.slidedeck = $(elem);
        this.elems.frame = this.elems.slidedeck.closest('.slidedeck-frame');
        this.elems.navs = this.elems.frame.find('.deck-navigation');
        
        // Fail silently for those SlideDecks that have no navigation
        if(this.elems.navs.length < 1){
            return false;
        }
        
        this.elems.previousHorizontal = this.elems.navs.filter('.horizontal.prev');
        this.elems.nextHorizontal = this.elems.navs.filter('.horizontal.next');
        this.elems.previousVertical = this.elems.navs.filter('.vertical.prev');
        this.elems.nextVertical = this.elems.navs.filter('.vertical.next');
        
        this.slidedeck = this.elems.slidedeck.slidedeck();
        
        // Adding global prev/next bindings
        this.elems.frame.delegate('.deck-navigation', 'click', function(event){
            event.preventDefault();
            self.nav(this.href.split('#')[1]);
        });
        
        var oldBefore = this.slidedeck.options.before;
        this.slidedeck.setOption('before', function(deck){
            if(typeof(oldBefore) == 'function')
                oldBefore(deck);
            
            self.checkHorizontal();
            self.checkVertical();
        });
        
        if(this.slidedeck.verticalSlides){
            this.slidedeck.slides.each(function(ind){
                if(self.slidedeck.verticalSlides[ind]){
                    if(typeof(self.slidedeck.verticalSlides[ind].slides) != 'undefined'){
                        var oldVerticalComplete = self.slidedeck.vertical().options.complete;
                        self.slidedeck.vertical().options.complete = function(vDeck){
                            if(typeof(oldVerticalComplete) == 'function')
                                oldVerticalComplete(vDeck);
                            
                            self.checkVertical();
                        };
                    }
                }
            });
        }
        
        // Hover class event
        if(this.elems.frame.hasClass('display-nav-hover')){
            this.elems.frame.mouseenter(function(event){
                self.elems.frame.addClass('hover');
            }).mouseleave(function(event){
                self.elems.frame.removeClass('hover');
            });
        }
        
        // Hide the horizontal navigation if we don't have more than one slide
        if(this.slidedeck.slides.length == 1){
            this.elems.frame.find('.deck-navigation.horizontal').hide();
        }
        
        this.checkVertical();
        this.checkHorizontal();
    };
    
    // Close the Overlay
    SlideDeckOverlay.prototype.close = function(){
        var self = this;
        
        this.elems.container.removeClass('open');
        this.elems.container.width(0);
    };
    
    // SlideDeckOverlay Class initialization
    SlideDeckOverlay.prototype.initialize = function(elem){
        var self = this;
        
        // The SlideDeck DOM element
        this.elems.slidedeck = $(elem);
        // The SlideDeck frame element
        this.elems.frame = this.elems.slidedeck.closest('.slidedeck-frame');
        
        // Fail silently if this is a malformed SlideDeck for overlays
        if(this.elems.frame.length < 1){
            return false;
        }
        
        // Fail silently if overlays don't exist for manual decks
        if(this.elems.frame.find('.' + this.classes.container).length < 1){
            return false;
        }
        
        if(__slidedeck2_isMobile() && this.elems.frame.hasClass('show-overlay-hover')){
            this.elems.frame.removeClass('show-overlay-hover');
            this.elems.frame.addClass('show-overlay-always');
        }
        
        /**
         * Hide the video cover on iOS. 
         */
        if(__slidedeck2_isiOS()){
            this.elems.frame.addClass('sd2-is-ios');
        }
        
        // The SlideDeck Overlay container
        this.elems.container = this.elems.frame.find('.' + this.classes.container);
        // The SlideDeck Overlay toggle button
        this.elems.toggle = this.elems.container.find('.' + this.classes.toggle);
        // The SlideDeck Overlay buttons wrapper
        this.elems.wrapper = this.elems.container.find('.' + this.classes.wrapper);
        // The SlideDeck Overlay buttons
        this.elems.overlays = this.elems.wrapper.find('.' + this.classes.overlay);
        
        if(this.elems.container.offset().left < this.elems.frame.outerWidth()/2){
            this.elems.container.addClass('left');
        }
        
        this.overlayWidth = 2;
        this.elems.overlays.each(function(ind){
            self.overlayWidth += self.elems.overlays.eq(ind).outerWidth();
        });
        
        if(this.elems.frame.hasClass('show-overlay-never')){
            return false;
        } else if(this.elems.frame.hasClass('show-overlay-hover')){
            this.elems.frame.bind('mouseenter', function(event){
                self.elems.frame.addClass('hover');
            }).bind('mouseleave', function(event){
                self.elems.frame.removeClass('hover');
            });
        }
        
        // Overlay toggle event
        this.elems.container.delegate('.' + this.classes.toggle, 'click', function(event){
            event.preventDefault();
            self.toggle();
        });
        
        // Overlay click action
        this.elems.container.delegate('.' + this.classes.overlay, 'click', function(event){
            // Get $(this) from the data cache
            var $this = $.data(this, '$this');
            
            // If $(this) is not cached, get it and cache it
            if(!$this){
                $this = $(this);
                // Store $(this) in the data cache
                $.data(this, '$this', $this);
            }
            
            // Get the Overlay type
            var type = $this.attr('data-type');
            
            // Run the Overlay type's action if it exists
            if(typeof(SlideDeckOverlays.actions[type]) == 'function'){
                SlideDeckOverlays.actions[type](this, event);
            }
        });
        
        // Prepare Overlay buttons
        this.elems.overlays.each(function(ind){
            // Get $(this) from the data cache
            var $this = $.data(this, '$this');
            
            // If $(this) is not cached, get it and cache it
            if(!$this){
                $this = $(this);
                // Store $(this) in the data cache
                $.data(this, '$this', $this);
            }
            
            // Get the Overlay type
            var type = $this.attr('data-type');
            
            // Run the Overlay type's init function if it exists
            if(typeof(SlideDeckOverlays.inits[type]) == 'function'){
                SlideDeckOverlays.inits[type](this);
            }
        });
        
        if(this.elems.frame.hasClass(SlideDeckPrefix + "overlays-open")){
            this.open();
        }
    };
    
    // Open the overlay
    SlideDeckOverlay.prototype.open = function(){
        var self = this;
        
        this.elems.container.addClass('open');
        this.elems.container.width(this.overlayWidth);
    };
    
    // Toggle the Overlay open or closed
    SlideDeckOverlay.prototype.toggle = function(){
        if(!this.elems.container.hasClass('open'))
            this.open();
        else
            this.close();
    };
    
    // Facebook Overlay link click action
    SlideDeckOverlays.actions['facebook'] = function(elem, event){
        event.preventDefault();

        var $this = $.data(elem, '$this');
        
        if(!$this){
            $this = $(elem);
            $.data(elem, '$this', $this);
        }
        
        // Get the parent window (which can also be the current window) in case its an iframe SlideDeck embed
        var $window = $(parent);
        
        // Setup offsets for positioning
        var offset = {
            top: parent.screenY || parent.screenTop,        // screenTop for IE compatibility
            left: parent.screenX || parent.screenLeft,      // screenLeft for IE compatibility
            width: $window.outerWidth(),
            height: $window.outerHeight()
        };
        
        // Get popup dimensions from data attributes from the PHP object
        var pos = {
            width: parseInt($this.attr('data-popup-width'), 10),
            height: parseInt($this.attr('data-popup-height'), 10)
        };
        
        // Center this puppy
        pos.top = offset.height/2 - pos.height/2 + offset.top;
        pos.left = offset.width/2 - pos.width/2 + offset.left;
        
        window.open(elem.href, "_slidedeck_overlay", "width=" + pos.width + ",height=" + pos.height + ",channelmode=no,directories=no,fullscreen=no,location=yes,resizable=yes,menubar=no,scrollbars=yes,status=no,titlebar=yes,left=" + pos.left + ",top=" + pos.top );
    };
    // Initialize Facebook Overlay links
    SlideDeckOverlays.inits['facebook'] = function(elem){
        // Fill in the blanks when no URL was found - primarily for iframe embedded SlideDecks
        var url = parent.document.location.href.replace(parent.document.location.hash, "");
        elem.href = elem.href.replace(/u\=(\#|\%23)/, "u=" + escape(url + "#"));
    };
    
    // Initialize Twitter Overlay links
    SlideDeckOverlays.inits['twitter'] = function(elem){
        // Fill in the blanks when no URL was found - primarily for iframe embedded SlideDecks
        var url = parent.document.location.href.replace(parent.document.location.hash, "");
        elem.href = elem.href.replace(/url\=(\#|\%23)/, "url=" + escape(url + "#"));
    };

    // Lazy Loading
    SlideDeckLazyLoad.prototype.lazyLoadImages = function( currentIndex ){
        var self = this;

        var images = $(this.slidedeck.slides[currentIndex]);
        if( __isVerticalDeck(this.slidedeck.deck) ){
            currentIndex = currentIndex--;
            images = $(this.slidedeck.vertical().slides[currentIndex]);
        }

        if( images.find('[data-sd2-slide-image]').length != 0 ){
            // Check and Load current Image
            var thisSlideImage = images.find('[data-sd2-slide-image]');
            var imageSrc = thisSlideImage.data('sd2-slide-image');
            thisSlideImage.addClass('sd2-image-lazy-loading');

            var imageObject = new Image();
            $(imageObject).load(function(event){
                if( thisSlideImage.prop("tagName") == "IMG" ){
                    thisSlideImage.attr('src', imageSrc );
                }else{
                    thisSlideImage.css( 'background-image', 'url(' + imageSrc + ')' );
                }
                self.slidedeck.deck.trigger( 'slidedeck:image-lazy-loaded', [ currentIndex, imageSrc, self.slidedeck ] );
                thisSlideImage.removeClass('sd2-image-lazy-loading');
            }).attr('src', imageSrc);

            thisSlideImage.removeAttr('data-sd2-slide-image');
        }
    };
    SlideDeckLazyLoad.prototype.lazyLoadVideos = function( currentIndex ){
        currentSlideElement = this.slidedeck.slides.eq( currentIndex );
        if( __isVerticalDeck(this.slidedeck.deck) ){
            currentSlideElement = this.slidedeck.vertical().slides.eq( currentIndex );
        }
        if( currentSlideElement.hasClass('slide-type-video') ) {
            if( !currentSlideElement.data('sd2-lazy-loaded') ){
                this.slidedeck.deck.data('video-slidedeck').loadYouTubeVideo( this.slidedeck.deck, currentIndex );
                this.slidedeck.deck.data('video-slidedeck').loadVimeoVideo( this.slidedeck.deck, currentIndex );
                this.slidedeck.deck.data('video-slidedeck').loadDailyMotionVideo( this.slidedeck.deck, currentIndex );
            }
            currentSlideElement.data('sd2-lazy-loaded', true);
        }
    };
    SlideDeckLazyLoad.prototype.lazyLoadNext = function( currentIndex, lazyLoadPadding ){
        var self = this;

        var slidesLength = self.slidedeck.slides.length;
        if( __isVerticalDeck(self.slidedeck.deck) ){
            slidesLength = self.slidedeck.vertical().slides.length;
        }

        // Note that the next slide padding is exaggerated by the <=
        // this is intentional.
        for( var i = 0; i <= lazyLoadPadding; i++ ){
            var next = currentIndex + i + 1;
            if( next >= slidesLength ){
                next = i + 1;
            }
            self.lazyLoadImages( next );
        }

        // Videos don't get the same amplification as above
        // as they are much heavier
        for( var i = 0; i < lazyLoadPadding; i++ ){
            var next = currentIndex + i + 1;
            if( next >= slidesLength ){
                next = i + 1;
            }
            self.lazyLoadVideos( next );
        }

        clearTimeout( self.lazyLoadPrevTimer );
        self.lazyLoadPrevTimer = setTimeout(function(){
            // Check and load prev image(s) - based off lazyLoadPadding
            self.lazyLoadPrev( currentIndex, lazyLoadPadding );
        }, Math.round( self.deckAnimationSpeed / 2 ) );
    };
    SlideDeckLazyLoad.prototype.lazyLoadPrev = function( currentIndex, lazyLoadPadding ){
        var self = this;

        var slidesLength = self.slidedeck.slides.length;
        if( __isVerticalDeck(self.slidedeck.deck) ){
            slidesLength = self.slidedeck.vertical().slides.length;
        }

        for( var i = 0; i < lazyLoadPadding; i++ ){
            var prev = currentIndex - i - 1;
            if( prev < 0 ){
                prev = slidesLength - i - 1;
            }
            self.lazyLoadImages( prev );
            self.lazyLoadVideos( prev );
        }
    };
    SlideDeckLazyLoad.prototype.lazyLoad = function(){
        var self = this;

        var currentIndex = self.slidedeck.current - 1;
        if( __isVerticalDeck(self.slidedeck.deck) ){
            currentIndex = self.slidedeck.vertical().current;
        }
        var lazyLoadPadding = self.slidedeck.options.lazyLoadPadding;

        self.lazyLoadImages( currentIndex );
        self.lazyLoadVideos( currentIndex );

        // Preload the next image in the deck
        clearTimeout( self.lazyLoadNextTimer );
        self.lazyLoadNextTimer = setTimeout(function(){
            // Check and load next image(s) - based off lazyLoadPadding
            self.lazyLoadNext( currentIndex, lazyLoadPadding );
        }, self.deckAnimationSpeed );
    };
    // SlideDeckLazyLoad Class initialization
    SlideDeckLazyLoad.prototype.initialize = function(elem){
        var self = this;

        this.elems.slidedeck = $(elem);
        this.elems.frame = this.elems.slidedeck.closest('.slidedeck-frame');            
        this.slidedeck = this.elems.slidedeck.slidedeck();
        this.deckAnimationSpeed = this.slidedeck.options.speed;

        // Let's cautiously set this in case a lens has tried to already
        var defaultLazyLoadPadding = this.elems.frame.data('sd2-lazy-load-padding');
        if( typeof( defaultLazyLoadPadding ) === 'undefined' )
            defaultLazyLoadPadding = 1;

        this.slidedeck.options.lazyLoadPadding = defaultLazyLoadPadding;
        
        var oldBefore = this.slidedeck.options.before;
        this.slidedeck.setOption('before', function(deck){
            if(typeof(oldBefore) === 'function')
                oldBefore(deck);
            
            // Lazyload
            self.lazyLoad( deck.current );
        });
        
        if(this.slidedeck.verticalSlides){
            this.slidedeck.slides.each(function(ind){
                if(self.slidedeck.verticalSlides[ind]){
                    if(typeof(self.slidedeck.verticalSlides[ind].slides) != 'undefined'){
                        var oldVerticalBefore = self.slidedeck.vertical().options.before;
                        self.slidedeck.vertical().options.before = function(vDeck){
                            if(typeof(oldVerticalBefore) == 'function')
                                oldVerticalBefore(vDeck);
                            
                            // Lazyload
                            self.lazyLoad( vDeck.current + 1 );
                        };
                    };
                };
            });
        };
        
        this.slidedeck.loaded(function(deck){
            self.lazyLoad( deck.current );
        });
    };
    
    $(document).ready(function(){
        // Initialize Overlays and nav for each SlideDeck
        $('.slidedeck').each(function(){
            var $slidedeck = $(this);
            
            if(!$.data(this, 'SlideDeckFadingNav'))
                $.data(this, 'SlideDeckFadingNav', new SlideDeckFadingNav(this));
                
            if(!$.data(this, 'SlideDeckOverlay'))
                $.data(this, 'SlideDeckOverlay', new SlideDeckOverlay(this));
                
            $slidedeck.has('.slide-type-video').each(function(){
                if(typeof($.data(this, 'video-slidedeck')) == 'undefined'){
                    $.data(this, 'video-slidedeck', new SlideDeckVideoAPIs(this));
                }
            });
            
            if(!$.data(this, 'SlideDeckLazyLoad')) $.data(this, 'SlideDeckLazyLoad', new SlideDeckLazyLoad(this));
            
            // Only for IE - detect background image url and update style for DD element
            if( ie ){
                if( ie <= 8.0 ){
                    $slidedeck.find('.sd2-slide-background').each(function(){
                        var $slideBackground = $(this);
                        var $slide = $slideBackground.closest('dd');

                        if( $slideBackground.css('background-image') != 'none' ){
                            var imgurl = $slideBackground.css('background-image').match( /url\([\"\'](.*)[\"\']\)/ )[1];
                            this.style.background = "none";
                            
                            var sizingMethod = "scale";
                            if($slide.hasClass('sd2-image-scaling-none')){
                                sizingMethod = "image";
                            }
                            
                            this.style.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(src='" + imgurl + "', sizingMethod='" + sizingMethod + "')";
                        }
                    });
                }
            }
        });
    });
})(jQuery);

/**
 * SlideDeck Cover Class
 * 
 * Copyright (C) 2012 digital-telepathy, http://www.dtelepathy.com
 * 
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 * 
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 * 
 * You should have received a copy of the GNU General Public License
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 * 
 * @author digital-telepathy
 * @package SlideDeck
 * @subpackage SlideDeck 2.0
 * @version 1.0
 */
var SlideDeckCoverPostProcessFront = {};
var SlideDeckCoverPostProcessBack = {};
var SlideDeckCover = function(elem){
    // Elements used by this Cover
    this.elems = {};
    
    // Original slidedeckOptions
    this.slidedeckOptions = {};
    
    // Does this SlideDeck have a Front Cover?
    this.hasFront = false;
    // Does this SlideDeck have a Back Cover?
    this.hasBack = false;
    
    // Classes used by this Cover
    this.classes = {
        backCover: 'slidedeck-cover-back',
        cover: 'slidedeck-cover',
        frame: 'slidedeck-frame',
        frontCover: 'slidedeck-cover-front',
        mask: 'slidedeck-cover-mask',
        nav: 'deck-navigation',
        open: 'slidedeck-cover-open',
        overlay: 'slidedeck-overlays',
        restart: 'slidedeck-cover-restart',
        wrapper: 'slidedeck-cover-wrapper'
    };
    
    this.easing = {
        smooth: {
            front: 'easeInCubic',
            back: 'easeOutCubic'
        },
        back: {
            front: 'easeSlideDeckCoverEaseIn',
            back: 'easeSlideDeckCoverEaseOut'
        }
    };
    
    // Animation speed
    this.speed = 750;
    
    // The SlideDeck object
    this.slidedeck = null;
    
    // Visible status of the back cover
    this.backCoverVisible = false;
    
    // Style of the cover
    this.coverStyle = "";
    
    // Initialize the Cover for this SlideDeck
    this.initialize(elem);
};

(function($){
    jQuery.extend(jQuery.easing, {
        easeSlideDeckCoverEaseIn: function (x, t, b, c, d, s) {
            if (s == undefined) s = 0.9;
            return c*(t/=d)*t*((s+1)*t - s) + b;
        },
        easeSlideDeckCoverEaseOut: function (x, t, b, c, d, s) {
            if (s == undefined) s = 0.9;
            return c*((t=t/d-1)*t*((s+1)*t + s) + 1) + b;
        }
    });
    
    SlideDeckCover.prototype.close = function(){
        var self = this;
        
        this.backCoverVisible = true;

        this.slidedeck.setOption('keys', false);
        this.slidedeck.setOption('scroll', false);
        this.slidedeck.pauseAutoPlay = true;
        
        this.elems.frame.addClass('force-nav-hidden');
        this.elems.overlay.fadeOut(this.speed);
        
        this.elems.backCover.css({
            zIndex: 1000,
            display: 'block'
        });
        
        var outerWidth = this.elems.backWrapper.outerWidth();
        
        this.elems.backWrapper.css({
            right: 0 - outerWidth
        }).animate({
            right: 0
        }, this.speed, this.easing[this.easingStyle()].back);
        
        this.elems.backMask.animate({
            opacity: 0.8
        }, this.speed);
    };
    
    SlideDeckCover.prototype.easingStyle = function(){
        var easing = "back";
        
        var matches = this.elems.frame[0].className.match(/slidedeck-cover-easing-([a-z0-9A-Z\-]+)/);
        if(matches.length > 1){
            easing = matches[1];
        }
        
        return easing;
    };
    
    SlideDeckCover.prototype.open = function(){
        var self = this;
        
        this.slidedeck.pauseAutoPlay = false;
        this.slidedeck.options.keys = this.slidedeckOptions.keys;
        this.slidedeck.options.scroll = this.slidedeckOptions.scroll;
        
        // Allow Nav to Show
        this.elems.frame.removeClass('force-nav-hidden');
        
        if(!this.elems.frame.hasClass('show-overlay-never')){
            if(this.elems.frame.hasClass('show-overlay-hover')){
                this.elems.overlay.removeAttr('style');
            } else {
                this.elems.overlay.animate({
                    opacity: 1
                }, this.speed);
            }
        }
        
        var outerWidth = this.elems.frontWrapper.outerWidth();
        
        this.elems.frontWrapper.animate({
            left: 0 - outerWidth
        }, this.speed, this.easing[this.easingStyle()].front);
        
        this.elems.frontMask.fadeOut(this.speed, function(){
            self.elems.frontCover.hide();
        });
    };
    
    SlideDeckCover.prototype.revert = function(){
        var self = this;
        
        this.backCoverVisible = true;
        if(__isVerticalDeck(this.slidedeck)){
            this.slidedeck.goToVertical(1);
        } else {
            this.slidedeck.goTo(1);
        }
        this.slidedeck.setOption('keys', this.slidedeckOptions.keys);
        this.slidedeck.setOption('scroll', this.slidedeckOptions.scroll);
        this.slidedeck.pauseAutoPlay = false;
        
        // Allow Nav to Show
        this.elems.frame.removeClass('force-nav-hidden');
        this.elems.overlay.fadeIn(this.speed);
        
        var outerWidth = this.elems.backWrapper.outerWidth();
        
        this.elems.backWrapper.animate({
            right: 0 - outerWidth
        }, this.speed, this.easing[this.easingStyle()].back);
        
        this.elems.backMask.animate({
            opacity: 0
        }, this.speed, function(){
            self.elems.backCover.css('z-index', 1);
            self.backCoverVisible = false;
        });
    };
    
    // SlideDeck Cover initialization and setup
    SlideDeckCover.prototype.initialize = function(elem){
        var self = this;
        
        if( self.elems.frame ){
            if( self.elems.frame.hasClass('sd2-small') )
                return false;
        }
        
        // SlideDeck DL element
        this.elems.slidedeck = $(elem);
        // SlideDeck frame element
        this.elems.frame = this.elems.slidedeck.closest('.' + this.classes.frame);
        
        // Fail silently if this is a malformed SlideDeck for covers
        if(this.elems.frame.length < 1){
            return false;
        }
        
        // SlideDeck front cover element
        this.elems.frontCover = this.elems.frame.find('.' + this.classes.frontCover);
        // SlideDeck back cover element
        this.elems.backCover = this.elems.frame.find('.' + this.classes.backCover);
        // SlideDeck navigation elements
        this.elems.nav = this.elems.frame.find('.' + this.classes.nav);
        // SlideDeck overlay
        this.elems.overlay = this.elems.frame.find('.' + this.classes.overlay);
        
        this.slidedeck = this.elems.slidedeck.slidedeck();
        // Make a copy of the original SlideDeck options to revert settings later if needed
        this.slidedeckOptions = $.extend(this.slidedeckOptions, this.slidedeck.options);
        
        var coverMatches = this.elems.frame[0].className.match(/slidedeck-cover-style-([a-z0-9A-Z\-]+)/);
        if( coverMatches ){
            if(coverMatches.length > 1){
                this.coverStyle = coverMatches[1];
            }
            
            var easingMatches = this.elems.frame[0].className.match(/slidedeck-cover-easing-([a-z0-9A-Z\-]+)/);
            if(!easingMatches){
                this.elems.frame.addClass('slidedeck-cover-easing-back');
            }
            
            // Check if we have a front cover and initialize it if we do
            if(this.elems.frontCover.length){
                this.hasFront = true;
                this.initializeFront();
            }
            
            // Check if we have a front cover and initialize it if we do
            if(this.elems.backCover.length){
                this.hasBack = true;
                this.initializeBack();
            }
        }
    };
    
    SlideDeckCover.prototype.initializeBack = function(){
        var self = this;
        
        if( self.elems.frame ){
            if( self.elems.frame.hasClass('sd2-small') )
                return false;
        }
        
        // SlideDeck back cover wrapper element
        this.elems.backWrapper = this.elems.backCover.find('.' + this.classes.wrapper);
        // Cover Mask
        this.elems.backMask = this.elems.backCover.find('.' + this.classes.mask);
        // SlideDeck cover restart button
        this.elems.restart = this.elems.backCover.find('.' + this.classes.restart);
        
        // Get the old before option
        var oldBefore = this.slidedeck.options.before;
        
        this.slidedeck.setOption('before', function(slidedeck){
            // If the old before option was a function, run it
            if(typeof(oldBefore) == 'function')
                oldBefore(slidedeck);
            
            if(
                ((slidedeck.current == 1 && slidedeck.former == slidedeck.slides.length)     // Cycle boolean(true)
                || (slidedeck.current == slidedeck.former && slidedeck.current == slidedeck.slides.length && slidedeck.options.cycle == false))   // Cycle boolean(false)
                && slidedeck.slides.length > 1
            ){
                if(self.backCoverVisible == false){
                    slidedeck.current = slidedeck.slides.length;
                    self.close();
                }
            }
        });
        
        this.elems.restart.bind('click', function(event){
            event.preventDefault();
            self.revert();
        });
        
        // Run the CTA PostProcess function for the hover color
        if( typeof( SlideDeckCoverPostProcessCTA ) == 'function' ){
            SlideDeckCoverPostProcessCTA( this.elems.restart );
        }
        
        if(SlideDeckCoverPostProcessBack[this.coverStyle])
            SlideDeckCoverPostProcessBack[this.coverStyle](this.elems.restart, this.elems.frame.hasClass('slidedeck-cover-peek'));
            
        self.elems.backCover.hide();
    };
    
    SlideDeckCover.prototype.initializeFront = function(){
        var self = this;
        
        if( self.elems.frame ){
            if( self.elems.frame.hasClass('sd2-small') )
                return false;
        }
        
        // SlideDeck front cover wrapper element
        this.elems.frontWrapper = this.elems.frontCover.find('.' + this.classes.wrapper);
        // Cover Mask
        this.elems.frontMask = this.elems.frontCover.find('.' + this.classes.mask);
        // SlideDeck cover open button
        this.elems.open = this.elems.frontCover.find('.' + this.classes.open);
        
        // Hide SlideDeck navigation
        this.elems.frame.addClass('force-nav-hidden');
        this.elems.overlay.css('opacity', 0);
        
        // Pause autoplay to prevent automatic progression while the cover is closed
        this.slidedeck.pauseAutoPlay = true;
        this.slidedeck.setOption('keys', false);
        this.slidedeck.setOption('scroll', false);
        
        // Attach open event
        this.elems.open.bind('click', function(event){
            event.preventDefault();
            self.open();
        });
        
        if(this.slidedeck.options.autoPlay == true){
            setTimeout(function(){
                self.open();
            }, this.slidedeck.options.autoPlayInterval);
        }
        
        // Run the CTA PostProcess function for the hover color
        if( typeof( SlideDeckCoverPostProcessCTA ) == 'function' ){
            SlideDeckCoverPostProcessCTA( this.elems.open );
        }
        
        if(SlideDeckCoverPostProcessFront[this.coverStyle])
            SlideDeckCoverPostProcessFront[this.coverStyle](this.elems.open, this.elems.frame.hasClass('slidedeck-cover-peek'));
        
        $(window).load(function(){
            self.elems.frontMask.animate({
                opacity: 0.35
            }, 1000);
        });
    };
    
    SlideDeckCoverPostProcessFront['leather'] = function($button, peek){
        var $color = $button.find('.slidedeck-cover-color');
        
        var accentColor = $color.css('background-color');
        var rgb = Raphael.getRGB(accentColor);
        var hsl = Raphael.rgb2hsl(rgb.r, rgb.g, rgb.b);
            hsl.l = Math.min(100, (110 * hsl.l))/100;
        var hoverColor = Raphael.hsl(hsl.h, hsl.s, hsl.l);
        
        var r = Raphael($color[0], 42, 84 );
        var offset = peek ? 0 : 42;
        var shape = r.ellipse(offset, 42, 41, 42);
            shape.attr({
                'stroke': 'none',
                'fill': accentColor
            });
        
        $color.css('background-color', "").data('slidedeck-cover-shape', shape);
        
        $button.bind('mouseenter', function(event){
            shape.attr('fill', hoverColor);
        }).bind('mouseleave', function(event){
            shape.attr('fill', accentColor);
        });
        
        $button.closest('.slidedeck-frame')[0].className = $button.closest('.slidedeck-frame')[0].className.replace(/slidedeck-cover-easing-([a-z0-9A-Z\-]+)/, "slidedeck-cover-easing-back");
    };
    
    SlideDeckCoverPostProcessBack['leather'] = function($button, peek){
        var $color = $button.find('.slidedeck-cover-color');
        
        var accentColor = $color.css('background-color');
        var rgb = Raphael.getRGB(accentColor);
        var hsl = Raphael.rgb2hsl(rgb.r, rgb.g, rgb.b);
            hsl.l = Math.min(100, (110 * hsl.l))/100;
        var hoverColor = Raphael.hsl(hsl.h, hsl.s, hsl.l);
        
        // Semicircle
        var r = Raphael($color[0], 42, 84 );
        var offset = peek ? 42 : 0;
        var shape = r.ellipse( offset, 42, 41, 42);
            shape.attr({
                'stroke': 'none',
                'fill': accentColor
            });
        
        $button.bind('mouseenter', function(event){
            shape.attr('fill', hoverColor);
        }).bind('mouseleave', function(event){
            shape.attr('fill', accentColor);
        });
        
        // CTA Button
        var ctaButton = $button.parents('.slidedeck-cover-wrapper').find('.slidedeck-cover-cta');
        var ctaButtonColor = ctaButton.find('.slidedeck-cover-color');

        ctaButtonColor.find('.cap2').remove();
        ctaButtonColor.find('.cap2-image').remove();
        ctaButton.find('.cap1').remove();
        ctaButton.find('.cap1-image').remove();

        ctaButtonColor.append('<div class="cap2"></div>');
        ctaButtonColor.append('<div class="cap2-image"></div>');
        ctaButton.append('<div class="cap1"></div>');
        ctaButton.append('<div class="cap1-image"></div>');
        var r1 = Raphael(ctaButton.find('.cap1')[0], 32, 57 );
        var r2 = Raphael(ctaButtonColor.find('.cap2')[0], 32, 57 );
        var cap1 = r1.ellipse( 31, 29, 26, 26);
        cap1.attr({fill:accentColor});
        var cap2 = r2.ellipse( 0, 29, 26, 26);
        cap2.attr({fill:accentColor});
        
        $color.css('background-color', "").data('slidedeck-cover-shape', [shape, cap1, cap2]);
        
        ctaButton.bind('mouseenter', function(event){
            cap1.attr('fill', hoverColor);
            cap2.attr('fill', hoverColor);
        }).bind('mouseleave', function(event){
            cap1.attr('fill', accentColor);
            cap2.attr('fill', accentColor);
        });
        
        $button.closest('.slidedeck-frame')[0].className = $button.closest('.slidedeck-frame')[0].className.replace(/slidedeck-cover-easing-([a-z0-9A-Z\-]+)/, "slidedeck-cover-easing-back");
    };
    
    SlideDeckCoverPostProcessFront['book'] = function($button, peek){
        var $color = $button.find('.slidedeck-cover-color');
        
        var accentColor = $color.css('background-color');
        var rgb = Raphael.getRGB(accentColor);
        var hsl = Raphael.rgb2hsl(rgb.r, rgb.g, rgb.b);
            hsl.l = Math.min(100, (110 * hsl.l))/100;
        var hoverColor = Raphael.hsl(hsl.h, hsl.s, hsl.l);
        
        var r = Raphael($color[0], 90, 72);
        
        if(peek){
            var shape = r.path("M84.246,0.901c-4.648-0.482-11.957-0.625-22.065-0.822L60.646,0.05  C58.979,0.017,57.227,0,55.445,0C33.884,0,5.432,2.263,0,2.712c0,0.037,0,0.111,0,0.201v67.831c0,0,29.504-2.716,49-2  c23.397,0.86,40.878,4.236,40.878-1.404c0-0.154,0-0.354,0-0.596c0.099,0.03,0.205,0.057,0.297,0.09c0-4.062,0-64.046,0-64.046  C90.176,2.31,89.408,1.434,84.246,0.901z");
        } else {
            var shape = r.path("M92.65,2.782c0,0-37.278-3.218-61.673-2.739 C9.446,0.466,0.471,0.56,0.471,3.781c0,3.626,0,59.199,0,66.549c-0.053-0.429,0.106-0.775,0.436-1.061 c1.439,4.389,14.292,1.716,35.801,1.333c18.233-0.327,55.941,1.146,55.941,1.146v-0.941h0.001V2.782z");
        }
        shape.attr({
            'stroke': 'none',
            'fill': accentColor
        });
        
        $color.css('background-color', "").data('slidedeck-cover-shape', shape);
        
        $button.bind('mouseenter', function(event){
            shape.attr('fill', hoverColor);
        }).bind('mouseleave', function(event){
            shape.attr('fill', accentColor);
        });
        
        $button.closest('.slidedeck-frame')[0].className = $button.closest('.slidedeck-frame')[0].className.replace(/slidedeck-cover-easing-([a-z0-9A-Z\-]+)/, "slidedeck-cover-easing-smooth");
    };
    
    SlideDeckCoverPostProcessBack['book'] = function($button, peek){
        var $color = $button.find('.slidedeck-cover-color');
        
        var accentColor = $color.css('background-color');
        var rgb = Raphael.getRGB(accentColor);
        var hsl = Raphael.rgb2hsl(rgb.r, rgb.g, rgb.b);
            hsl.l = Math.min(100, (110 * hsl.l))/100;
        var hoverColor = Raphael.hsl(hsl.h, hsl.s, hsl.l);
        
        var r = Raphael($color[0], 90, 72);
        
        var shape = r.path("M92.65,2.782c0,0-37.278-3.218-61.673-2.739 C9.446,0.466,0.471,0.56,0.471,3.781c0,3.626,0,59.199,0,66.549c-0.053-0.429,0.106-0.775,0.436-1.061 c1.439,4.389,14.292,1.716,35.801,1.333c18.233-0.327,55.941,1.146,55.941,1.146v-0.941h0.001V2.782z");
        shape.attr({
            'stroke': 'none',
            'fill': accentColor
        });
        
        $color.css('background-color', "").data('slidedeck-cover-shape', shape);
        
        // Button mouseover for SVG
        $button.bind('mouseenter', function(event){
            shape.attr('fill', hoverColor);
        }).bind('mouseleave', function(event){
            shape.attr('fill', accentColor);
        });
        
        $button.closest('.slidedeck-frame')[0].className = $button.closest('.slidedeck-frame')[0].className.replace(/slidedeck-cover-easing-([a-z0-9A-Z\-]+)/, "slidedeck-cover-easing-smooth");
    };
    
    SlideDeckCoverPostProcessFront['glass'] = function($button, peek){
        var $color = $button.find('.slidedeck-cover-color');
        
        var accentColor = $color.css('background-color');
        var rgb = Raphael.getRGB(accentColor);
        var hsl = Raphael.rgb2hsl(rgb.r, rgb.g, rgb.b);
            hsl.l = Math.min(100, (110 * hsl.l))/100;
        var hoverColor = Raphael.hsl(hsl.h, hsl.s, hsl.l);
        
        var frostedColor1 = Raphael.rgb2hsb(rgb.r,rgb.g,rgb.b);
        frostedColor1.s = frostedColor1.s * 0.2;
        frostedColor1.b = 1;
        
        var frostedColor2 = Raphael.rgb2hsb(rgb.r,rgb.g,rgb.b);
        frostedColor2.s = frostedColor2.s * 0.05;
        frostedColor2.b = 1;
        
        var glassGradient = '90-hsb('+ frostedColor1.h +','+ frostedColor1.s +','+ frostedColor1.b +')-hsb('+ frostedColor2.h +','+ frostedColor2.s +','+ frostedColor2.b +')';
        
        // Remnove the frosted area if it exists...
        $button.parents('.slidedeck-cover-front').find('.frosted-glass').remove();
        
        // Add the frosted area...
        $button.parents('.slidedeck-cover-front').find('.slidedeck-cover-copy').append('<div class="frosted-glass"></div>');
        var frosted = $button.parents('.slidedeck-cover-wrapper').find('.frosted-glass');
        var frostedWidth = frosted.width();
        var frostedHeight = frosted.height();
        
        var r = Raphael( frosted[0], frostedWidth, frostedHeight);
        var radius = 25;
        var offset = 10;
        var path = "M0,0";
        // Top
        path += "H" + frostedWidth;
        // Right
        path += "V" + frostedHeight;
        // Bottom
        path += "H0";
        // Left
        path += "z";
        // Circle?
        path += "M "+ parseInt( frostedWidth - ( radius * 2 ) - offset, 10 ) +" "+ parseInt( frostedHeight/2, 10 ) +" a "+ radius +" "+ radius +" 0 1 0 0 "+ -0.0001;
        
        // Arrow
        path += "m14,-6h13v-4l12,11,l-12,11,v-4h-13";
        
        var frostedPathBackground = r.path( path );
        frostedPathBackground.attr({
            stroke: "none",
            fill: 'url(' + slideDeck2URLPath + '/images/frosted-glass-noise.png)',
            opacity: 1
        });
        
        var frostedPath = r.path( path );
        frostedPath.attr({
            stroke: "none",
            fill: glassGradient,
            opacity: 0.6
        });
        frosted.data('slidedeck-frosted-cover-background', frostedPath);
        
        var path = "M0,0";
        // Top
        path += "H" + frostedWidth;
        // Right
        path += "V" + frostedHeight * 0.1;
        // Quadratic point
        path += "Q" + frostedWidth * 0.3 + "," + frostedHeight * 0.3 + ", 0 " + frostedHeight * 0.85;
        // Left
        path += "z";
        
        var shinePath = r.path( path );
        shinePath.attr({
            stroke: "none",
            fill: glassGradient,
            opacity: 0.2
        });
        frosted.data('slidedeck-frosted-cover-shine', shinePath);
    };
    
    SlideDeckCoverPostProcessBack['glass'] = function($button, peek){
        var $color = $button.find('.slidedeck-cover-color');
        
        var accentColor = $color.css('background-color');
        var rgb = Raphael.getRGB(accentColor);
        var hsl = Raphael.rgb2hsl(rgb.r, rgb.g, rgb.b);
            hsl.l = Math.min(100, (110 * hsl.l))/100;
        var hoverColor = Raphael.hsl(hsl.h, hsl.s, hsl.l);
        
        var frostedColor1 = Raphael.rgb2hsb(rgb.r,rgb.g,rgb.b);
        frostedColor1.s = frostedColor1.s * 0.2;
        frostedColor1.b = 1;
        var frostedColor2 = Raphael.rgb2hsb(rgb.r,rgb.g,rgb.b);
        frostedColor2.s = frostedColor2.s * 0.05;
        frostedColor2.b = 1;
        var glassGradient = '90-hsb('+ frostedColor1.h +','+ frostedColor1.s +','+ frostedColor1.b +')-hsb('+ frostedColor2.h +','+ frostedColor2.s +','+ frostedColor2.b +')';
        
        // Remnove the frosted area if it exists...
        $button.parents('.slidedeck-cover-back').find('.frosted-glass-back').remove();

        // Add the frosted area...
        $button.parents('.slidedeck-cover-back').find('.slidedeck-cover-copy').append('<div class="frosted-glass-back"></div>');
        var frosted = $button.parents('.slidedeck-cover-back').find('.frosted-glass-back');
        var frostedWidth = frosted.width();
        var frostedHeight = frosted.height();
        
        var r = Raphael( frosted[0], frostedWidth, frostedHeight);
        var radius = 25;
        var offset = 10;
        var path = "M0,0";
        // Top
        path += "H" + frostedWidth;
        // Right
        path += "V" + frostedHeight;
        // Bottom
        path += "H0";
        // Left
        path += "z";
        // Circle cutout
        path += "M "+ parseInt( radius - offset, 10 ) +" "+ parseInt( frostedHeight/2, 10 ) +" a "+ radius +" "+ radius +" 0 1 0 0 "+ -0.0001;
        
        var frostedPathBackground = r.path( path );
        frostedPathBackground.attr({
            stroke: "none",
            fill: 'url(' + slideDeck2URLPath + '/images/frosted-glass-noise.png)',
            opacity: 1
        });
        
        var frostedPath = r.path( path );
        frostedPath.attr({
            stroke: "none",
            fill: glassGradient,
            opacity: 0.6
        });
        frosted.data('slidedeck-frosted-cover-back-background', frostedPath);
        
        var path = "M0,0";
        // Top
        path += "H" + frostedWidth;
        // Right
        path += "V" + frostedHeight * 0.1;
        // Quadratic point
        path += "Q" + frostedWidth * 0.3 + "," + frostedHeight * 0.3 + ", 0 " + frostedHeight * 0.85;
        // Left
        path += "z";
        
        // Circle cutout
        path += "M "+ parseInt( ( radius ) - offset, 10 ) +" "+ parseInt( frostedHeight/2, 10 ) +" a "+ radius +" "+ radius +" 0 1 0 0 "+ -0.0001;
        
        var shinePath = r.path( path );
        shinePath.attr({
            stroke: "none",
            fill: glassGradient,
            opacity: 0.2
        });
        frosted.data('slidedeck-frosted-cover-back-shine', shinePath);
    };
    
    var SlideDeckCoverPostProcessCTA = function( $button ){
        var $color = $button.find('.slidedeck-cover-color');
        var accentColor = $color.css('background-color');
        
        var rgb = Raphael.getRGB(accentColor);
        var hsl = Raphael.rgb2hsl(rgb.r, rgb.g, rgb.b);
            hsl.l = Math.min(100, (110 * hsl.l))/100;
        var hoverColor = Raphael.hsl(hsl.h, hsl.s, hsl.l);
        
        $button.parent().delegate('.slidedeck-cover-cta', 'mouseenter mouseleave', function(event){
            if( event.type == 'mouseenter' ){
                $(this).find('.slidedeck-cover-color').css({ backgroundColor: hoverColor });
            }else{
                $(this).find('.slidedeck-cover-color').css({ backgroundColor: accentColor });
            }
        });
    };
    
    $(document).ready(function(){
        $('.slidedeck').each(function(){
            if(!$.data(this, 'SlideDeckCover'))
                $.data(this, 'SlideDeckCover', new SlideDeckCover(this));
        });
    });
})(jQuery);

/**
 * *****************************************
 * SlideDeck Bug Link to New Tab/Window + Toggle
 * *****************************************
 */
(function($){
    var slideDeckBugExternalToggle = {
        linkTargets: function(c){
            var timer = new Array();
            var links = this.setContext(c).context.find('.slidedeck-frame a.slidedeck-2-bug[rel*="external"]');
            links.attr('target','_blank');
            
            links.each( function( ind ) {
                var $bug = $(this);
                $bug.addClass('open');
                
                timer[ind] = window.setTimeout( function(){
                    $bug.removeClass('open');
                }, 3000 );
                
                $bug.on( 'mouseenter', function( event ) {
                    window.clearTimeout( timer[ind] );
                    $bug.addClass( 'open' );
                } ).on( 'mouseleave', function( event ) {
                    $bug.removeClass( 'open' );
                } );
            } );

            return this;
        },
        setContext: function(c){
            if(typeof(c) != "undefined"){
                this.context = $(c);
            }
            return this;
        },
        initialize: function(c){
            if(typeof(c) == "undefined"){
                c = $(document.body);
            }
            this.setContext(c).linkTargets();
        }
    };
    $(document).ready(function(){
        slideDeckBugExternalToggle.initialize();
    });
})(jQuery);

/*!
// ┌────────────────────────────────────────────────────────────────────┐ \\
// │ Raphaël 2.1.0 - JavaScript Vector Library                          │ \\
// ├────────────────────────────────────────────────────────────────────┤ \\
// │ Copyright © 2008-2012 Dmitry Baranovskiy (http://raphaeljs.com)    │ \\
// │ Copyright © 2008-2012 Sencha Labs (http://sencha.com)              │ \\
// ├────────────────────────────────────────────────────────────────────┤ \\
// │ Licensed under the MIT (http://raphaeljs.com/license.html) license.│ \\
// └────────────────────────────────────────────────────────────────────┘ \\
*/
(function(a){var b="0.3.4",c="hasOwnProperty",d=/[\.\/]/,e="*",f=function(){},g=function(a,b){return a-b},h,i,j={n:{}},k=function(a,b){var c=j,d=i,e=Array.prototype.slice.call(arguments,2),f=k.listeners(a),l=0,m=!1,n,o=[],p={},q=[],r=h,s=[];h=a,i=0;for(var t=0,u=f.length;t<u;t++)"zIndex"in f[t]&&(o.push(f[t].zIndex),f[t].zIndex<0&&(p[f[t].zIndex]=f[t]));o.sort(g);while(o[l]<0){n=p[o[l++]],q.push(n.apply(b,e));if(i){i=d;return q}}for(t=0;t<u;t++){n=f[t];if("zIndex"in n)if(n.zIndex==o[l]){q.push(n.apply(b,e));if(i)break;do{l++,n=p[o[l]],n&&q.push(n.apply(b,e));if(i)break}while(n)}else p[n.zIndex]=n;else{q.push(n.apply(b,e));if(i)break}}i=d,h=r;return q.length?q:null};k.listeners=function(a){var b=a.split(d),c=j,f,g,h,i,k,l,m,n,o=[c],p=[];for(i=0,k=b.length;i<k;i++){n=[];for(l=0,m=o.length;l<m;l++){c=o[l].n,g=[c[b[i]],c[e]],h=2;while(h--)f=g[h],f&&(n.push(f),p=p.concat(f.f||[]))}o=n}return p},k.on=function(a,b){var c=a.split(d),e=j;for(var g=0,h=c.length;g<h;g++)e=e.n,!e[c[g]]&&(e[c[g]]={n:{}}),e=e[c[g]];e.f=e.f||[];for(g=0,h=e.f.length;g<h;g++)if(e.f[g]==b)return f;e.f.push(b);return function(a){+a==+a&&(b.zIndex=+a)}},k.stop=function(){i=1},k.nt=function(a){if(a)return(new RegExp("(?:\\.|\\/|^)"+a+"(?:\\.|\\/|$)")).test(h);return h},k.off=k.unbind=function(a,b){var f=a.split(d),g,h,i,k,l,m,n,o=[j];for(k=0,l=f.length;k<l;k++)for(m=0;m<o.length;m+=i.length-2){i=[m,1],g=o[m].n;if(f[k]!=e)g[f[k]]&&i.push(g[f[k]]);else for(h in g)g[c](h)&&i.push(g[h]);o.splice.apply(o,i)}for(k=0,l=o.length;k<l;k++){g=o[k];while(g.n){if(b){if(g.f){for(m=0,n=g.f.length;m<n;m++)if(g.f[m]==b){g.f.splice(m,1);break}!g.f.length&&delete g.f}for(h in g.n)if(g.n[c](h)&&g.n[h].f){var p=g.n[h].f;for(m=0,n=p.length;m<n;m++)if(p[m]==b){p.splice(m,1);break}!p.length&&delete g.n[h].f}}else{delete g.f;for(h in g.n)g.n[c](h)&&g.n[h].f&&delete g.n[h].f}g=g.n}}},k.once=function(a,b){var c=function(){var d=b.apply(this,arguments);k.unbind(a,c);return d};return k.on(a,c)},k.version=b,k.toString=function(){return"You are running Eve "+b},typeof module!="undefined"&&module.exports?module.exports=k:typeof define!="undefined"?define("eve",[],function(){return k}):a.eve=k})(this),function(){function cF(a){for(var b=0;b<cy.length;b++)cy[b].el.paper==a&&cy.splice(b--,1)}function cE(b,d,e,f,h,i){e=Q(e);var j,k,l,m=[],o,p,q,t=b.ms,u={},v={},w={};if(f)for(y=0,z=cy.length;y<z;y++){var x=cy[y];if(x.el.id==d.id&&x.anim==b){x.percent!=e?(cy.splice(y,1),l=1):k=x,d.attr(x.totalOrigin);break}}else f=+v;for(var y=0,z=b.percents.length;y<z;y++){if(b.percents[y]==e||b.percents[y]>f*b.top){e=b.percents[y],p=b.percents[y-1]||0,t=t/b.top*(e-p),o=b.percents[y+1],j=b.anim[e];break}f&&d.attr(b.anim[b.percents[y]])}if(!!j){if(!k){for(var A in j)if(j[g](A))if(U[g](A)||d.paper.customAttributes[g](A)){u[A]=d.attr(A),u[A]==null&&(u[A]=T[A]),v[A]=j[A];switch(U[A]){case C:w[A]=(v[A]-u[A])/t;break;case"colour":u[A]=a.getRGB(u[A]);var B=a.getRGB(v[A]);w[A]={r:(B.r-u[A].r)/t,g:(B.g-u[A].g)/t,b:(B.b-u[A].b)/t};break;case"path":var D=bR(u[A],v[A]),E=D[1];u[A]=D[0],w[A]=[];for(y=0,z=u[A].length;y<z;y++){w[A][y]=[0];for(var F=1,G=u[A][y].length;F<G;F++)w[A][y][F]=(E[y][F]-u[A][y][F])/t}break;case"transform":var H=d._,I=ca(H[A],v[A]);if(I){u[A]=I.from,v[A]=I.to,w[A]=[],w[A].real=!0;for(y=0,z=u[A].length;y<z;y++){w[A][y]=[u[A][y][0]];for(F=1,G=u[A][y].length;F<G;F++)w[A][y][F]=(v[A][y][F]-u[A][y][F])/t}}else{var J=d.matrix||new cb,K={_:{transform:H.transform},getBBox:function(){return d.getBBox(1)}};u[A]=[J.a,J.b,J.c,J.d,J.e,J.f],b$(K,v[A]),v[A]=K._.transform,w[A]=[(K.matrix.a-J.a)/t,(K.matrix.b-J.b)/t,(K.matrix.c-J.c)/t,(K.matrix.d-J.d)/t,(K.matrix.e-J.e)/t,(K.matrix.f-J.f)/t]}break;case"csv":var L=r(j[A])[s](c),M=r(u[A])[s](c);if(A=="clip-rect"){u[A]=M,w[A]=[],y=M.length;while(y--)w[A][y]=(L[y]-u[A][y])/t}v[A]=L;break;default:L=[][n](j[A]),M=[][n](u[A]),w[A]=[],y=d.paper.customAttributes[A].length;while(y--)w[A][y]=((L[y]||0)-(M[y]||0))/t}}var O=j.easing,P=a.easing_formulas[O];if(!P){P=r(O).match(N);if(P&&P.length==5){var R=P;P=function(a){return cC(a,+R[1],+R[2],+R[3],+R[4],t)}}else P=bf}q=j.start||b.start||+(new Date),x={anim:b,percent:e,timestamp:q,start:q+(b.del||0),status:0,initstatus:f||0,stop:!1,ms:t,easing:P,from:u,diff:w,to:v,el:d,callback:j.callback,prev:p,next:o,repeat:i||b.times,origin:d.attr(),totalOrigin:h},cy.push(x);if(f&&!k&&!l){x.stop=!0,x.start=new Date-t*f;if(cy.length==1)return cA()}l&&(x.start=new Date-x.ms*f),cy.length==1&&cz(cA)}else k.initstatus=f,k.start=new Date-k.ms*f;eve("raphael.anim.start."+d.id,d,b)}}function cD(a,b){var c=[],d={};this.ms=b,this.times=1;if(a){for(var e in a)a[g](e)&&(d[Q(e)]=a[e],c.push(Q(e)));c.sort(bd)}this.anim=d,this.top=c[c.length-1],this.percents=c}function cC(a,b,c,d,e,f){function o(a,b){var c,d,e,f,j,k;for(e=a,k=0;k<8;k++){f=m(e)-a;if(z(f)<b)return e;j=(3*i*e+2*h)*e+g;if(z(j)<1e-6)break;e=e-f/j}c=0,d=1,e=a;if(e<c)return c;if(e>d)return d;while(c<d){f=m(e);if(z(f-a)<b)return e;a>f?c=e:d=e,e=(d-c)/2+c}return e}function n(a,b){var c=o(a,b);return((l*c+k)*c+j)*c}function m(a){return((i*a+h)*a+g)*a}var g=3*b,h=3*(d-b)-g,i=1-g-h,j=3*c,k=3*(e-c)-j,l=1-j-k;return n(a,1/(200*f))}function cq(){return this.x+q+this.y+q+this.width+" × "+this.height}function cp(){return this.x+q+this.y}function cb(a,b,c,d,e,f){a!=null?(this.a=+a,this.b=+b,this.c=+c,this.d=+d,this.e=+e,this.f=+f):(this.a=1,this.b=0,this.c=0,this.d=1,this.e=0,this.f=0)}function bH(b,c,d){b=a._path2curve(b),c=a._path2curve(c);var e,f,g,h,i,j,k,l,m,n,o=d?0:[];for(var p=0,q=b.length;p<q;p++){var r=b[p];if(r[0]=="M")e=i=r[1],f=j=r[2];else{r[0]=="C"?(m=[e,f].concat(r.slice(1)),e=m[6],f=m[7]):(m=[e,f,e,f,i,j,i,j],e=i,f=j);for(var s=0,t=c.length;s<t;s++){var u=c[s];if(u[0]=="M")g=k=u[1],h=l=u[2];else{u[0]=="C"?(n=[g,h].concat(u.slice(1)),g=n[6],h=n[7]):(n=[g,h,g,h,k,l,k,l],g=k,h=l);var v=bG(m,n,d);if(d)o+=v;else{for(var w=0,x=v.length;w<x;w++)v[w].segment1=p,v[w].segment2=s,v[w].bez1=m,v[w].bez2=n;o=o.concat(v)}}}}}return o}function bG(b,c,d){var e=a.bezierBBox(b),f=a.bezierBBox(c);if(!a.isBBoxIntersect(e,f))return d?0:[];var g=bB.apply(0,b),h=bB.apply(0,c),i=~~(g/5),j=~~(h/5),k=[],l=[],m={},n=d?0:[];for(var o=0;o<i+1;o++){var p=a.findDotsAtSegment.apply(a,b.concat(o/i));k.push({x:p.x,y:p.y,t:o/i})}for(o=0;o<j+1;o++)p=a.findDotsAtSegment.apply(a,c.concat(o/j)),l.push({x:p.x,y:p.y,t:o/j});for(o=0;o<i;o++)for(var q=0;q<j;q++){var r=k[o],s=k[o+1],t=l[q],u=l[q+1],v=z(s.x-r.x)<.001?"y":"x",w=z(u.x-t.x)<.001?"y":"x",x=bD(r.x,r.y,s.x,s.y,t.x,t.y,u.x,u.y);if(x){if(m[x.x.toFixed(4)]==x.y.toFixed(4))continue;m[x.x.toFixed(4)]=x.y.toFixed(4);var y=r.t+z((x[v]-r[v])/(s[v]-r[v]))*(s.t-r.t),A=t.t+z((x[w]-t[w])/(u[w]-t[w]))*(u.t-t.t);y>=0&&y<=1&&A>=0&&A<=1&&(d?n++:n.push({x:x.x,y:x.y,t1:y,t2:A}))}}return n}function bF(a,b){return bG(a,b,1)}function bE(a,b){return bG(a,b)}function bD(a,b,c,d,e,f,g,h){if(!(x(a,c)<y(e,g)||y(a,c)>x(e,g)||x(b,d)<y(f,h)||y(b,d)>x(f,h))){var i=(a*d-b*c)*(e-g)-(a-c)*(e*h-f*g),j=(a*d-b*c)*(f-h)-(b-d)*(e*h-f*g),k=(a-c)*(f-h)-(b-d)*(e-g);if(!k)return;var l=i/k,m=j/k,n=+l.toFixed(2),o=+m.toFixed(2);if(n<+y(a,c).toFixed(2)||n>+x(a,c).toFixed(2)||n<+y(e,g).toFixed(2)||n>+x(e,g).toFixed(2)||o<+y(b,d).toFixed(2)||o>+x(b,d).toFixed(2)||o<+y(f,h).toFixed(2)||o>+x(f,h).toFixed(2))return;return{x:l,y:m}}}function bC(a,b,c,d,e,f,g,h,i){if(!(i<0||bB(a,b,c,d,e,f,g,h)<i)){var j=1,k=j/2,l=j-k,m,n=.01;m=bB(a,b,c,d,e,f,g,h,l);while(z(m-i)>n)k/=2,l+=(m<i?1:-1)*k,m=bB(a,b,c,d,e,f,g,h,l);return l}}function bB(a,b,c,d,e,f,g,h,i){i==null&&(i=1),i=i>1?1:i<0?0:i;var j=i/2,k=12,l=[-0.1252,.1252,-0.3678,.3678,-0.5873,.5873,-0.7699,.7699,-0.9041,.9041,-0.9816,.9816],m=[.2491,.2491,.2335,.2335,.2032,.2032,.1601,.1601,.1069,.1069,.0472,.0472],n=0;for(var o=0;o<k;o++){var p=j*l[o]+j,q=bA(p,a,c,e,g),r=bA(p,b,d,f,h),s=q*q+r*r;n+=m[o]*w.sqrt(s)}return j*n}function bA(a,b,c,d,e){var f=-3*b+9*c-9*d+3*e,g=a*f+6*b-12*c+6*d;return a*g-3*b+3*c}function by(a,b){var c=[];for(var d=0,e=a.length;e-2*!b>d;d+=2){var f=[{x:+a[d-2],y:+a[d-1]},{x:+a[d],y:+a[d+1]},{x:+a[d+2],y:+a[d+3]},{x:+a[d+4],y:+a[d+5]}];b?d?e-4==d?f[3]={x:+a[0],y:+a[1]}:e-2==d&&(f[2]={x:+a[0],y:+a[1]},f[3]={x:+a[2],y:+a[3]}):f[0]={x:+a[e-2],y:+a[e-1]}:e-4==d?f[3]=f[2]:d||(f[0]={x:+a[d],y:+a[d+1]}),c.push(["C",(-f[0].x+6*f[1].x+f[2].x)/6,(-f[0].y+6*f[1].y+f[2].y)/6,(f[1].x+6*f[2].x-f[3].x)/6,(f[1].y+6*f[2].y-f[3].y)/6,f[2].x,f[2].y])}return c}function bx(){return this.hex}function bv(a,b,c){function d(){var e=Array.prototype.slice.call(arguments,0),f=e.join("␀"),h=d.cache=d.cache||{},i=d.count=d.count||[];if(h[g](f)){bu(i,f);return c?c(h[f]):h[f]}i.length>=1e3&&delete h[i.shift()],i.push(f),h[f]=a[m](b,e);return c?c(h[f]):h[f]}return d}function bu(a,b){for(var c=0,d=a.length;c<d;c++)if(a[c]===b)return a.push(a.splice(c,1)[0])}function bm(a){if(Object(a)!==a)return a;var b=new a.constructor;for(var c in a)a[g](c)&&(b[c]=bm(a[c]));return b}function a(c){if(a.is(c,"function"))return b?c():eve.on("raphael.DOMload",c);if(a.is(c,E))return a._engine.create[m](a,c.splice(0,3+a.is(c[0],C))).add(c);var d=Array.prototype.slice.call(arguments,0);if(a.is(d[d.length-1],"function")){var e=d.pop();return b?e.call(a._engine.create[m](a,d)):eve.on("raphael.DOMload",function(){e.call(a._engine.create[m](a,d))})}return a._engine.create[m](a,arguments)}a.version="2.1.0",a.eve=eve;var b,c=/[, ]+/,d={circle:1,rect:1,path:1,ellipse:1,text:1,image:1},e=/\{(\d+)\}/g,f="prototype",g="hasOwnProperty",h={doc:document,win:window},i={was:Object.prototype[g].call(h.win,"Raphael"),is:h.win.Raphael},j=function(){this.ca=this.customAttributes={}},k,l="appendChild",m="apply",n="concat",o="createTouch"in h.doc,p="",q=" ",r=String,s="split",t="click dblclick mousedown mousemove mouseout mouseover mouseup touchstart touchmove touchend touchcancel"[s](q),u={mousedown:"touchstart",mousemove:"touchmove",mouseup:"touchend"},v=r.prototype.toLowerCase,w=Math,x=w.max,y=w.min,z=w.abs,A=w.pow,B=w.PI,C="number",D="string",E="array",F="toString",G="fill",H=Object.prototype.toString,I={},J="push",K=a._ISURL=/^url\(['"]?([^\)]+?)['"]?\)$/i,L=/^\s*((#[a-f\d]{6})|(#[a-f\d]{3})|rgba?\(\s*([\d\.]+%?\s*,\s*[\d\.]+%?\s*,\s*[\d\.]+%?(?:\s*,\s*[\d\.]+%?)?)\s*\)|hsba?\(\s*([\d\.]+(?:deg|\xb0|%)?\s*,\s*[\d\.]+%?\s*,\s*[\d\.]+(?:%?\s*,\s*[\d\.]+)?)%?\s*\)|hsla?\(\s*([\d\.]+(?:deg|\xb0|%)?\s*,\s*[\d\.]+%?\s*,\s*[\d\.]+(?:%?\s*,\s*[\d\.]+)?)%?\s*\))\s*$/i,M={NaN:1,Infinity:1,"-Infinity":1},N=/^(?:cubic-)?bezier\(([^,]+),([^,]+),([^,]+),([^\)]+)\)/,O=w.round,P="setAttribute",Q=parseFloat,R=parseInt,S=r.prototype.toUpperCase,T=a._availableAttrs={"arrow-end":"none","arrow-start":"none",blur:0,"clip-rect":"0 0 1e9 1e9",cursor:"default",cx:0,cy:0,fill:"#fff","fill-opacity":1,font:'10px "Arial"',"font-family":'"Arial"',"font-size":"10","font-style":"normal","font-weight":400,gradient:0,height:0,href:"http://raphaeljs.com/","letter-spacing":0,opacity:1,path:"M0,0",r:0,rx:0,ry:0,src:"",stroke:"#000","stroke-dasharray":"","stroke-linecap":"butt","stroke-linejoin":"butt","stroke-miterlimit":0,"stroke-opacity":1,"stroke-width":1,target:"_blank","text-anchor":"middle",title:"Raphael",transform:"",width:0,x:0,y:0},U=a._availableAnimAttrs={blur:C,"clip-rect":"csv",cx:C,cy:C,fill:"colour","fill-opacity":C,"font-size":C,height:C,opacity:C,path:"path",r:C,rx:C,ry:C,stroke:"colour","stroke-opacity":C,"stroke-width":C,transform:"transform",width:C,x:C,y:C},V=/[\x09\x0a\x0b\x0c\x0d\x20\xa0\u1680\u180e\u2000\u2001\u2002\u2003\u2004\u2005\u2006\u2007\u2008\u2009\u200a\u202f\u205f\u3000\u2028\u2029]/g,W=/[\x09\x0a\x0b\x0c\x0d\x20\xa0\u1680\u180e\u2000\u2001\u2002\u2003\u2004\u2005\u2006\u2007\u2008\u2009\u200a\u202f\u205f\u3000\u2028\u2029]*,[\x09\x0a\x0b\x0c\x0d\x20\xa0\u1680\u180e\u2000\u2001\u2002\u2003\u2004\u2005\u2006\u2007\u2008\u2009\u200a\u202f\u205f\u3000\u2028\u2029]*/,X={hs:1,rg:1},Y=/,?([achlmqrstvxz]),?/gi,Z=/([achlmrqstvz])[\x09\x0a\x0b\x0c\x0d\x20\xa0\u1680\u180e\u2000\u2001\u2002\u2003\u2004\u2005\u2006\u2007\u2008\u2009\u200a\u202f\u205f\u3000\u2028\u2029,]*((-?\d*\.?\d*(?:e[\-+]?\d+)?[\x09\x0a\x0b\x0c\x0d\x20\xa0\u1680\u180e\u2000\u2001\u2002\u2003\u2004\u2005\u2006\u2007\u2008\u2009\u200a\u202f\u205f\u3000\u2028\u2029]*,?[\x09\x0a\x0b\x0c\x0d\x20\xa0\u1680\u180e\u2000\u2001\u2002\u2003\u2004\u2005\u2006\u2007\u2008\u2009\u200a\u202f\u205f\u3000\u2028\u2029]*)+)/ig,$=/([rstm])[\x09\x0a\x0b\x0c\x0d\x20\xa0\u1680\u180e\u2000\u2001\u2002\u2003\u2004\u2005\u2006\u2007\u2008\u2009\u200a\u202f\u205f\u3000\u2028\u2029,]*((-?\d*\.?\d*(?:e[\-+]?\d+)?[\x09\x0a\x0b\x0c\x0d\x20\xa0\u1680\u180e\u2000\u2001\u2002\u2003\u2004\u2005\u2006\u2007\u2008\u2009\u200a\u202f\u205f\u3000\u2028\u2029]*,?[\x09\x0a\x0b\x0c\x0d\x20\xa0\u1680\u180e\u2000\u2001\u2002\u2003\u2004\u2005\u2006\u2007\u2008\u2009\u200a\u202f\u205f\u3000\u2028\u2029]*)+)/ig,_=/(-?\d*\.?\d*(?:e[\-+]?\d+)?)[\x09\x0a\x0b\x0c\x0d\x20\xa0\u1680\u180e\u2000\u2001\u2002\u2003\u2004\u2005\u2006\u2007\u2008\u2009\u200a\u202f\u205f\u3000\u2028\u2029]*,?[\x09\x0a\x0b\x0c\x0d\x20\xa0\u1680\u180e\u2000\u2001\u2002\u2003\u2004\u2005\u2006\u2007\u2008\u2009\u200a\u202f\u205f\u3000\u2028\u2029]*/ig,ba=a._radial_gradient=/^r(?:\(([^,]+?)[\x09\x0a\x0b\x0c\x0d\x20\xa0\u1680\u180e\u2000\u2001\u2002\u2003\u2004\u2005\u2006\u2007\u2008\u2009\u200a\u202f\u205f\u3000\u2028\u2029]*,[\x09\x0a\x0b\x0c\x0d\x20\xa0\u1680\u180e\u2000\u2001\u2002\u2003\u2004\u2005\u2006\u2007\u2008\u2009\u200a\u202f\u205f\u3000\u2028\u2029]*([^\)]+?)\))?/,bb={},bc=function(a,b){return a.key-b.key},bd=function(a,b){return Q(a)-Q(b)},be=function(){},bf=function(a){return a},bg=a._rectPath=function(a,b,c,d,e){if(e)return[["M",a+e,b],["l",c-e*2,0],["a",e,e,0,0,1,e,e],["l",0,d-e*2],["a",e,e,0,0,1,-e,e],["l",e*2-c,0],["a",e,e,0,0,1,-e,-e],["l",0,e*2-d],["a",e,e,0,0,1,e,-e],["z"]];return[["M",a,b],["l",c,0],["l",0,d],["l",-c,0],["z"]]},bh=function(a,b,c,d){d==null&&(d=c);return[["M",a,b],["m",0,-d],["a",c,d,0,1,1,0,2*d],["a",c,d,0,1,1,0,-2*d],["z"]]},bi=a._getPath={path:function(a){return a.attr("path")},circle:function(a){var b=a.attrs;return bh(b.cx,b.cy,b.r)},ellipse:function(a){var b=a.attrs;return bh(b.cx,b.cy,b.rx,b.ry)},rect:function(a){var b=a.attrs;return bg(b.x,b.y,b.width,b.height,b.r)},image:function(a){var b=a.attrs;return bg(b.x,b.y,b.width,b.height)},text:function(a){var b=a._getBBox();return bg(b.x,b.y,b.width,b.height)}},bj=a.mapPath=function(a,b){if(!b)return a;var c,d,e,f,g,h,i;a=bR(a);for(e=0,g=a.length;e<g;e++){i=a[e];for(f=1,h=i.length;f<h;f+=2)c=b.x(i[f],i[f+1]),d=b.y(i[f],i[f+1]),i[f]=c,i[f+1]=d}return a};a._g=h,a.type=h.win.SVGAngle||h.doc.implementation.hasFeature("http://www.w3.org/TR/SVG11/feature#BasicStructure","1.1")?"SVG":"VML";if(a.type=="VML"){var bk=h.doc.createElement("div"),bl;bk.innerHTML='<v:shape adj="1"/>',bl=bk.firstChild,bl.style.behavior="url(#default#VML)";if(!bl||typeof bl.adj!="object")return a.type=p;bk=null}a.svg=!(a.vml=a.type=="VML"),a._Paper=j,a.fn=k=j.prototype=a.prototype,a._id=0,a._oid=0,a.is=function(a,b){b=v.call(b);if(b=="finite")return!M[g](+a);if(b=="array")return a instanceof Array;return b=="null"&&a===null||b==typeof a&&a!==null||b=="object"&&a===Object(a)||b=="array"&&Array.isArray&&Array.isArray(a)||H.call(a).slice(8,-1).toLowerCase()==b},a.angle=function(b,c,d,e,f,g){if(f==null){var h=b-d,i=c-e;if(!h&&!i)return 0;return(180+w.atan2(-i,-h)*180/B+360)%360}return a.angle(b,c,f,g)-a.angle(d,e,f,g)},a.rad=function(a){return a%360*B/180},a.deg=function(a){return a*180/B%360},a.snapTo=function(b,c,d){d=a.is(d,"finite")?d:10;if(a.is(b,E)){var e=b.length;while(e--)if(z(b[e]-c)<=d)return b[e]}else{b=+b;var f=c%b;if(f<d)return c-f;if(f>b-d)return c-f+b}return c};var bn=a.createUUID=function(a,b){return function(){return"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(a,b).toUpperCase()}}(/[xy]/g,function(a){var b=w.random()*16|0,c=a=="x"?b:b&3|8;return c.toString(16)});a.setWindow=function(b){eve("raphael.setWindow",a,h.win,b),h.win=b,h.doc=h.win.document,a._engine.initWin&&a._engine.initWin(h.win)};var bo=function(b){if(a.vml){var c=/^\s+|\s+$/g,d;try{var e=new ActiveXObject("htmlfile");e.write("<body>"),e.close(),d=e.body}catch(f){d=createPopup().document.body}var g=d.createTextRange();bo=bv(function(a){try{d.style.color=r(a).replace(c,p);var b=g.queryCommandValue("ForeColor");b=(b&255)<<16|b&65280|(b&16711680)>>>16;return"#"+("000000"+b.toString(16)).slice(-6)}catch(e){return"none"}})}else{var i=h.doc.createElement("i");i.title="Raphaël Colour Picker",i.style.display="none",h.doc.body.appendChild(i),bo=bv(function(a){i.style.color=a;return h.doc.defaultView.getComputedStyle(i,p).getPropertyValue("color")})}return bo(b)},bp=function(){return"hsb("+[this.h,this.s,this.b]+")"},bq=function(){return"hsl("+[this.h,this.s,this.l]+")"},br=function(){return this.hex},bs=function(b,c,d){c==null&&a.is(b,"object")&&"r"in b&&"g"in b&&"b"in b&&(d=b.b,c=b.g,b=b.r);if(c==null&&a.is(b,D)){var e=a.getRGB(b);b=e.r,c=e.g,d=e.b}if(b>1||c>1||d>1)b/=255,c/=255,d/=255;return[b,c,d]},bt=function(b,c,d,e){b*=255,c*=255,d*=255;var f={r:b,g:c,b:d,hex:a.rgb(b,c,d),toString:br};a.is(e,"finite")&&(f.opacity=e);return f};a.color=function(b){var c;a.is(b,"object")&&"h"in b&&"s"in b&&"b"in b?(c=a.hsb2rgb(b),b.r=c.r,b.g=c.g,b.b=c.b,b.hex=c.hex):a.is(b,"object")&&"h"in b&&"s"in b&&"l"in b?(c=a.hsl2rgb(b),b.r=c.r,b.g=c.g,b.b=c.b,b.hex=c.hex):(a.is(b,"string")&&(b=a.getRGB(b)),a.is(b,"object")&&"r"in b&&"g"in b&&"b"in b?(c=a.rgb2hsl(b),b.h=c.h,b.s=c.s,b.l=c.l,c=a.rgb2hsb(b),b.v=c.b):(b={hex:"none"},b.r=b.g=b.b=b.h=b.s=b.v=b.l=-1)),b.toString=br;return b},a.hsb2rgb=function(a,b,c,d){this.is(a,"object")&&"h"in a&&"s"in a&&"b"in a&&(c=a.b,b=a.s,a=a.h,d=a.o),a*=360;var e,f,g,h,i;a=a%360/60,i=c*b,h=i*(1-z(a%2-1)),e=f=g=c-i,a=~~a,e+=[i,h,0,0,h,i][a],f+=[h,i,i,h,0,0][a],g+=[0,0,h,i,i,h][a];return bt(e,f,g,d)},a.hsl2rgb=function(a,b,c,d){this.is(a,"object")&&"h"in a&&"s"in a&&"l"in a&&(c=a.l,b=a.s,a=a.h);if(a>1||b>1||c>1)a/=360,b/=100,c/=100;a*=360;var e,f,g,h,i;a=a%360/60,i=2*b*(c<.5?c:1-c),h=i*(1-z(a%2-1)),e=f=g=c-i/2,a=~~a,e+=[i,h,0,0,h,i][a],f+=[h,i,i,h,0,0][a],g+=[0,0,h,i,i,h][a];return bt(e,f,g,d)},a.rgb2hsb=function(a,b,c){c=bs(a,b,c),a=c[0],b=c[1],c=c[2];var d,e,f,g;f=x(a,b,c),g=f-y(a,b,c),d=g==0?null:f==a?(b-c)/g:f==b?(c-a)/g+2:(a-b)/g+4,d=(d+360)%6*60/360,e=g==0?0:g/f;return{h:d,s:e,b:f,toString:bp}},a.rgb2hsl=function(a,b,c){c=bs(a,b,c),a=c[0],b=c[1],c=c[2];var d,e,f,g,h,i;g=x(a,b,c),h=y(a,b,c),i=g-h,d=i==0?null:g==a?(b-c)/i:g==b?(c-a)/i+2:(a-b)/i+4,d=(d+360)%6*60/360,f=(g+h)/2,e=i==0?0:f<.5?i/(2*f):i/(2-2*f);return{h:d,s:e,l:f,toString:bq}},a._path2string=function(){return this.join(",").replace(Y,"$1")};var bw=a._preload=function(a,b){var c=h.doc.createElement("img");c.style.cssText="position:absolute;left:-9999em;top:-9999em",c.onload=function(){b.call(this),this.onload=null,h.doc.body.removeChild(this)},c.onerror=function(){h.doc.body.removeChild(this)},h.doc.body.appendChild(c),c.src=a};a.getRGB=bv(function(b){if(!b||!!((b=r(b)).indexOf("-")+1))return{r:-1,g:-1,b:-1,hex:"none",error:1,toString:bx};if(b=="none")return{r:-1,g:-1,b:-1,hex:"none",toString:bx};!X[g](b.toLowerCase().substring(0,2))&&b.charAt()!="#"&&(b=bo(b));var c,d,e,f,h,i,j,k=b.match(L);if(k){k[2]&&(f=R(k[2].substring(5),16),e=R(k[2].substring(3,5),16),d=R(k[2].substring(1,3),16)),k[3]&&(f=R((i=k[3].charAt(3))+i,16),e=R((i=k[3].charAt(2))+i,16),d=R((i=k[3].charAt(1))+i,16)),k[4]&&(j=k[4][s](W),d=Q(j[0]),j[0].slice(-1)=="%"&&(d*=2.55),e=Q(j[1]),j[1].slice(-1)=="%"&&(e*=2.55),f=Q(j[2]),j[2].slice(-1)=="%"&&(f*=2.55),k[1].toLowerCase().slice(0,4)=="rgba"&&(h=Q(j[3])),j[3]&&j[3].slice(-1)=="%"&&(h/=100));if(k[5]){j=k[5][s](W),d=Q(j[0]),j[0].slice(-1)=="%"&&(d*=2.55),e=Q(j[1]),j[1].slice(-1)=="%"&&(e*=2.55),f=Q(j[2]),j[2].slice(-1)=="%"&&(f*=2.55),(j[0].slice(-3)=="deg"||j[0].slice(-1)=="°")&&(d/=360),k[1].toLowerCase().slice(0,4)=="hsba"&&(h=Q(j[3])),j[3]&&j[3].slice(-1)=="%"&&(h/=100);return a.hsb2rgb(d,e,f,h)}if(k[6]){j=k[6][s](W),d=Q(j[0]),j[0].slice(-1)=="%"&&(d*=2.55),e=Q(j[1]),j[1].slice(-1)=="%"&&(e*=2.55),f=Q(j[2]),j[2].slice(-1)=="%"&&(f*=2.55),(j[0].slice(-3)=="deg"||j[0].slice(-1)=="°")&&(d/=360),k[1].toLowerCase().slice(0,4)=="hsla"&&(h=Q(j[3])),j[3]&&j[3].slice(-1)=="%"&&(h/=100);return a.hsl2rgb(d,e,f,h)}k={r:d,g:e,b:f,toString:bx},k.hex="#"+(16777216|f|e<<8|d<<16).toString(16).slice(1),a.is(h,"finite")&&(k.opacity=h);return k}return{r:-1,g:-1,b:-1,hex:"none",error:1,toString:bx}},a),a.hsb=bv(function(b,c,d){return a.hsb2rgb(b,c,d).hex}),a.hsl=bv(function(b,c,d){return a.hsl2rgb(b,c,d).hex}),a.rgb=bv(function(a,b,c){return"#"+(16777216|c|b<<8|a<<16).toString(16).slice(1)}),a.getColor=function(a){var b=this.getColor.start=this.getColor.start||{h:0,s:1,b:a||.75},c=this.hsb2rgb(b.h,b.s,b.b);b.h+=.075,b.h>1&&(b.h=0,b.s-=.2,b.s<=0&&(this.getColor.start={h:0,s:1,b:b.b}));return c.hex},a.getColor.reset=function(){delete this.start},a.parsePathString=function(b){if(!b)return null;var c=bz(b);if(c.arr)return bJ(c.arr);var d={a:7,c:6,h:1,l:2,m:2,r:4,q:4,s:4,t:2,v:1,z:0},e=[];a.is(b,E)&&a.is(b[0],E)&&(e=bJ(b)),e.length||r(b).replace(Z,function(a,b,c){var f=[],g=b.toLowerCase();c.replace(_,function(a,b){b&&f.push(+b)}),g=="m"&&f.length>2&&(e.push([b][n](f.splice(0,2))),g="l",b=b=="m"?"l":"L");if(g=="r")e.push([b][n](f));else while(f.length>=d[g]){e.push([b][n](f.splice(0,d[g])));if(!d[g])break}}),e.toString=a._path2string,c.arr=bJ(e);return e},a.parseTransformString=bv(function(b){if(!b)return null;var c={r:3,s:4,t:2,m:6},d=[];a.is(b,E)&&a.is(b[0],E)&&(d=bJ(b)),d.length||r(b).replace($,function(a,b,c){var e=[],f=v.call(b);c.replace(_,function(a,b){b&&e.push(+b)}),d.push([b][n](e))}),d.toString=a._path2string;return d});var bz=function(a){var b=bz.ps=bz.ps||{};b[a]?b[a].sleep=100:b[a]={sleep:100},setTimeout(function(){for(var c in b)b[g](c)&&c!=a&&(b[c].sleep--,!b[c].sleep&&delete b[c])});return b[a]};a.findDotsAtSegment=function(a,b,c,d,e,f,g,h,i){var j=1-i,k=A(j,3),l=A(j,2),m=i*i,n=m*i,o=k*a+l*3*i*c+j*3*i*i*e+n*g,p=k*b+l*3*i*d+j*3*i*i*f+n*h,q=a+2*i*(c-a)+m*(e-2*c+a),r=b+2*i*(d-b)+m*(f-2*d+b),s=c+2*i*(e-c)+m*(g-2*e+c),t=d+2*i*(f-d)+m*(h-2*f+d),u=j*a+i*c,v=j*b+i*d,x=j*e+i*g,y=j*f+i*h,z=90-w.atan2(q-s,r-t)*180/B;(q>s||r<t)&&(z+=180);return{x:o,y:p,m:{x:q,y:r},n:{x:s,y:t},start:{x:u,y:v},end:{x:x,y:y},alpha:z}},a.bezierBBox=function(b,c,d,e,f,g,h,i){a.is(b,"array")||(b=[b,c,d,e,f,g,h,i]);var j=bQ.apply(null,b);return{x:j.min.x,y:j.min.y,x2:j.max.x,y2:j.max.y,width:j.max.x-j.min.x,height:j.max.y-j.min.y}},a.isPointInsideBBox=function(a,b,c){return b>=a.x&&b<=a.x2&&c>=a.y&&c<=a.y2},a.isBBoxIntersect=function(b,c){var d=a.isPointInsideBBox;return d(c,b.x,b.y)||d(c,b.x2,b.y)||d(c,b.x,b.y2)||d(c,b.x2,b.y2)||d(b,c.x,c.y)||d(b,c.x2,c.y)||d(b,c.x,c.y2)||d(b,c.x2,c.y2)||(b.x<c.x2&&b.x>c.x||c.x<b.x2&&c.x>b.x)&&(b.y<c.y2&&b.y>c.y||c.y<b.y2&&c.y>b.y)},a.pathIntersection=function(a,b){return bH(a,b)},a.pathIntersectionNumber=function(a,b){return bH(a,b,1)},a.isPointInsidePath=function(b,c,d){var e=a.pathBBox(b);return a.isPointInsideBBox(e,c,d)&&bH(b,[["M",c,d],["H",e.x2+10]],1)%2==1},a._removedFactory=function(a){return function(){eve("raphael.log",null,"Raphaël: you are calling to method “"+a+"” of removed object",a)}};var bI=a.pathBBox=function(a){var b=bz(a);if(b.bbox)return b.bbox;if(!a)return{x:0,y:0,width:0,height:0,x2:0,y2:0};a=bR(a);var c=0,d=0,e=[],f=[],g;for(var h=0,i=a.length;h<i;h++){g=a[h];if(g[0]=="M")c=g[1],d=g[2],e.push(c),f.push(d);else{var j=bQ(c,d,g[1],g[2],g[3],g[4],g[5],g[6]);e=e[n](j.min.x,j.max.x),f=f[n](j.min.y,j.max.y),c=g[5],d=g[6]}}var k=y[m](0,e),l=y[m](0,f),o=x[m](0,e),p=x[m](0,f),q={x:k,y:l,x2:o,y2:p,width:o-k,height:p-l};b.bbox=bm(q);return q},bJ=function(b){var c=bm(b);c.toString=a._path2string;return c},bK=a._pathToRelative=function(b){var c=bz(b);if(c.rel)return bJ(c.rel);if(!a.is(b,E)||!a.is(b&&b[0],E))b=a.parsePathString(b);var d=[],e=0,f=0,g=0,h=0,i=0;b[0][0]=="M"&&(e=b[0][1],f=b[0][2],g=e,h=f,i++,d.push(["M",e,f]));for(var j=i,k=b.length;j<k;j++){var l=d[j]=[],m=b[j];if(m[0]!=v.call(m[0])){l[0]=v.call(m[0]);switch(l[0]){case"a":l[1]=m[1],l[2]=m[2],l[3]=m[3],l[4]=m[4],l[5]=m[5],l[6]=+(m[6]-e).toFixed(3),l[7]=+(m[7]-f).toFixed(3);break;case"v":l[1]=+(m[1]-f).toFixed(3);break;case"m":g=m[1],h=m[2];default:for(var n=1,o=m.length;n<o;n++)l[n]=+(m[n]-(n%2?e:f)).toFixed(3)}}else{l=d[j]=[],m[0]=="m"&&(g=m[1]+e,h=m[2]+f);for(var p=0,q=m.length;p<q;p++)d[j][p]=m[p]}var r=d[j].length;switch(d[j][0]){case"z":e=g,f=h;break;case"h":e+=+d[j][r-1];break;case"v":f+=+d[j][r-1];break;default:e+=+d[j][r-2],f+=+d[j][r-1]}}d.toString=a._path2string,c.rel=bJ(d);return d},bL=a._pathToAbsolute=function(b){var c=bz(b);if(c.abs)return bJ(c.abs);if(!a.is(b,E)||!a.is(b&&b[0],E))b=a.parsePathString(b);if(!b||!b.length)return[["M",0,0]];var d=[],e=0,f=0,g=0,h=0,i=0;b[0][0]=="M"&&(e=+b[0][1],f=+b[0][2],g=e,h=f,i++,d[0]=["M",e,f]);var j=b.length==3&&b[0][0]=="M"&&b[1][0].toUpperCase()=="R"&&b[2][0].toUpperCase()=="Z";for(var k,l,m=i,o=b.length;m<o;m++){d.push(k=[]),l=b[m];if(l[0]!=S.call(l[0])){k[0]=S.call(l[0]);switch(k[0]){case"A":k[1]=l[1],k[2]=l[2],k[3]=l[3],k[4]=l[4],k[5]=l[5],k[6]=+(l[6]+e),k[7]=+(l[7]+f);break;case"V":k[1]=+l[1]+f;break;case"H":k[1]=+l[1]+e;break;case"R":var p=[e,f][n](l.slice(1));for(var q=2,r=p.length;q<r;q++)p[q]=+p[q]+e,p[++q]=+p[q]+f;d.pop(),d=d[n](by(p,j));break;case"M":g=+l[1]+e,h=+l[2]+f;default:for(q=1,r=l.length;q<r;q++)k[q]=+l[q]+(q%2?e:f)}}else if(l[0]=="R")p=[e,f][n](l.slice(1)),d.pop(),d=d[n](by(p,j)),k=["R"][n](l.slice(-2));else for(var s=0,t=l.length;s<t;s++)k[s]=l[s];switch(k[0]){case"Z":e=g,f=h;break;case"H":e=k[1];break;case"V":f=k[1];break;case"M":g=k[k.length-2],h=k[k.length-1];default:e=k[k.length-2],f=k[k.length-1]}}d.toString=a._path2string,c.abs=bJ(d);return d},bM=function(a,b,c,d){return[a,b,c,d,c,d]},bN=function(a,b,c,d,e,f){var g=1/3,h=2/3;return[g*a+h*c,g*b+h*d,g*e+h*c,g*f+h*d,e,f]},bO=function(a,b,c,d,e,f,g,h,i,j){var k=B*120/180,l=B/180*(+e||0),m=[],o,p=bv(function(a,b,c){var d=a*w.cos(c)-b*w.sin(c),e=a*w.sin(c)+b*w.cos(c);return{x:d,y:e}});if(!j){o=p(a,b,-l),a=o.x,b=o.y,o=p(h,i,-l),h=o.x,i=o.y;var q=w.cos(B/180*e),r=w.sin(B/180*e),t=(a-h)/2,u=(b-i)/2,v=t*t/(c*c)+u*u/(d*d);v>1&&(v=w.sqrt(v),c=v*c,d=v*d);var x=c*c,y=d*d,A=(f==g?-1:1)*w.sqrt(z((x*y-x*u*u-y*t*t)/(x*u*u+y*t*t))),C=A*c*u/d+(a+h)/2,D=A*-d*t/c+(b+i)/2,E=w.asin(((b-D)/d).toFixed(9)),F=w.asin(((i-D)/d).toFixed(9));E=a<C?B-E:E,F=h<C?B-F:F,E<0&&(E=B*2+E),F<0&&(F=B*2+F),g&&E>F&&(E=E-B*2),!g&&F>E&&(F=F-B*2)}else E=j[0],F=j[1],C=j[2],D=j[3];var G=F-E;if(z(G)>k){var H=F,I=h,J=i;F=E+k*(g&&F>E?1:-1),h=C+c*w.cos(F),i=D+d*w.sin(F),m=bO(h,i,c,d,e,0,g,I,J,[F,H,C,D])}G=F-E;var K=w.cos(E),L=w.sin(E),M=w.cos(F),N=w.sin(F),O=w.tan(G/4),P=4/3*c*O,Q=4/3*d*O,R=[a,b],S=[a+P*L,b-Q*K],T=[h+P*N,i-Q*M],U=[h,i];S[0]=2*R[0]-S[0],S[1]=2*R[1]-S[1];if(j)return[S,T,U][n](m);m=[S,T,U][n](m).join()[s](",");var V=[];for(var W=0,X=m.length;W<X;W++)V[W]=W%2?p(m[W-1],m[W],l).y:p(m[W],m[W+1],l).x;return V},bP=function(a,b,c,d,e,f,g,h,i){var j=1-i;return{x:A(j,3)*a+A(j,2)*3*i*c+j*3*i*i*e+A(i,3)*g,y:A(j,3)*b+A(j,2)*3*i*d+j*3*i*i*f+A(i,3)*h}},bQ=bv(function(a,b,c,d,e,f,g,h){var i=e-2*c+a-(g-2*e+c),j=2*(c-a)-2*(e-c),k=a-c,l=(-j+w.sqrt(j*j-4*i*k))/2/i,n=(-j-w.sqrt(j*j-4*i*k))/2/i,o=[b,h],p=[a,g],q;z(l)>"1e12"&&(l=.5),z(n)>"1e12"&&(n=.5),l>0&&l<1&&(q=bP(a,b,c,d,e,f,g,h,l),p.push(q.x),o.push(q.y)),n>0&&n<1&&(q=bP(a,b,c,d,e,f,g,h,n),p.push(q.x),o.push(q.y)),i=f-2*d+b-(h-2*f+d),j=2*(d-b)-2*(f-d),k=b-d,l=(-j+w.sqrt(j*j-4*i*k))/2/i,n=(-j-w.sqrt(j*j-4*i*k))/2/i,z(l)>"1e12"&&(l=.5),z(n)>"1e12"&&(n=.5),l>0&&l<1&&(q=bP(a,b,c,d,e,f,g,h,l),p.push(q.x),o.push(q.y)),n>0&&n<1&&(q=bP(a,b,c,d,e,f,g,h,n),p.push(q.x),o.push(q.y));return{min:{x:y[m](0,p),y:y[m](0,o)},max:{x:x[m](0,p),y:x[m](0,o)}}}),bR=a._path2curve=bv(function(a,b){var c=!b&&bz(a);if(!b&&c.curve)return bJ(c.curve);var d=bL(a),e=b&&bL(b),f={x:0,y:0,bx:0,by:0,X:0,Y:0,qx:null,qy:null},g={x:0,y:0,bx:0,by:0,X:0,Y:0,qx:null,qy:null},h=function(a,b){var c,d;if(!a)return["C",b.x,b.y,b.x,b.y,b.x,b.y];!(a[0]in{T:1,Q:1})&&(b.qx=b.qy=null);switch(a[0]){case"M":b.X=a[1],b.Y=a[2];break;case"A":a=["C"][n](bO[m](0,[b.x,b.y][n](a.slice(1))));break;case"S":c=b.x+(b.x-(b.bx||b.x)),d=b.y+(b.y-(b.by||b.y)),a=["C",c,d][n](a.slice(1));break;case"T":b.qx=b.x+(b.x-(b.qx||b.x)),b.qy=b.y+(b.y-(b.qy||b.y)),a=["C"][n](bN(b.x,b.y,b.qx,b.qy,a[1],a[2]));break;case"Q":b.qx=a[1],b.qy=a[2],a=["C"][n](bN(b.x,b.y,a[1],a[2],a[3],a[4]));break;case"L":a=["C"][n](bM(b.x,b.y,a[1],a[2]));break;case"H":a=["C"][n](bM(b.x,b.y,a[1],b.y));break;case"V":a=["C"][n](bM(b.x,b.y,b.x,a[1]));break;case"Z":a=["C"][n](bM(b.x,b.y,b.X,b.Y))}return a},i=function(a,b){if(a[b].length>7){a[b].shift();var c=a[b];while(c.length)a.splice(b++,0,["C"][n](c.splice(0,6)));a.splice(b,1),l=x(d.length,e&&e.length||0)}},j=function(a,b,c,f,g){a&&b&&a[g][0]=="M"&&b[g][0]!="M"&&(b.splice(g,0,["M",f.x,f.y]),c.bx=0,c.by=0,c.x=a[g][1],c.y=a[g][2],l=x(d.length,e&&e.length||0))};for(var k=0,l=x(d.length,e&&e.length||0);k<l;k++){d[k]=h(d[k],f),i(d,k),e&&(e[k]=h(e[k],g)),e&&i(e,k),j(d,e,f,g,k),j(e,d,g,f,k);var o=d[k],p=e&&e[k],q=o.length,r=e&&p.length;f.x=o[q-2],f.y=o[q-1],f.bx=Q(o[q-4])||f.x,f.by=Q(o[q-3])||f.y,g.bx=e&&(Q(p[r-4])||g.x),g.by=e&&(Q(p[r-3])||g.y),g.x=e&&p[r-2],g.y=e&&p[r-1]}e||(c.curve=bJ(d));return e?[d,e]:d},null,bJ),bS=a._parseDots=bv(function(b){var c=[];for(var d=0,e=b.length;d<e;d++){var f={},g=b[d].match(/^([^:]*):?([\d\.]*)/);f.color=a.getRGB(g[1]);if(f.color.error)return null;f.color=f.color.hex,g[2]&&(f.offset=g[2]+"%"),c.push(f)}for(d=1,e=c.length-1;d<e;d++)if(!c[d].offset){var h=Q(c[d-1].offset||0),i=0;for(var j=d+1;j<e;j++)if(c[j].offset){i=c[j].offset;break}i||(i=100,j=e),i=Q(i);var k=(i-h)/(j-d+1);for(;d<j;d++)h+=k,c[d].offset=h+"%"}return c}),bT=a._tear=function(a,b){a==b.top&&(b.top=a.prev),a==b.bottom&&(b.bottom=a.next),a.next&&(a.next.prev=a.prev),a.prev&&(a.prev.next=a.next)},bU=a._tofront=function(a,b){b.top!==a&&(bT(a,b),a.next=null,a.prev=b.top,b.top.next=a,b.top=a)},bV=a._toback=function(a,b){b.bottom!==a&&(bT(a,b),a.next=b.bottom,a.prev=null,b.bottom.prev=a,b.bottom=a)},bW=a._insertafter=function(a,b,c){bT(a,c),b==c.top&&(c.top=a),b.next&&(b.next.prev=a),a.next=b.next,a.prev=b,b.next=a},bX=a._insertbefore=function(a,b,c){bT(a,c),b==c.bottom&&(c.bottom=a),b.prev&&(b.prev.next=a),a.prev=b.prev,b.prev=a,a.next=b},bY=a.toMatrix=function(a,b){var c=bI(a),d={_:{transform:p},getBBox:function(){return c}};b$(d,b);return d.matrix},bZ=a.transformPath=function(a,b){return bj(a,bY(a,b))},b$=a._extractTransform=function(b,c){if(c==null)return b._.transform;c=r(c).replace(/\.{3}|\u2026/g,b._.transform||p);var d=a.parseTransformString(c),e=0,f=0,g=0,h=1,i=1,j=b._,k=new cb;j.transform=d||[];if(d)for(var l=0,m=d.length;l<m;l++){var n=d[l],o=n.length,q=r(n[0]).toLowerCase(),s=n[0]!=q,t=s?k.invert():0,u,v,w,x,y;q=="t"&&o==3?s?(u=t.x(0,0),v=t.y(0,0),w=t.x(n[1],n[2]),x=t.y(n[1],n[2]),k.translate(w-u,x-v)):k.translate(n[1],n[2]):q=="r"?o==2?(y=y||b.getBBox(1),k.rotate(n[1],y.x+y.width/2,y.y+y.height/2),e+=n[1]):o==4&&(s?(w=t.x(n[2],n[3]),x=t.y(n[2],n[3]),k.rotate(n[1],w,x)):k.rotate(n[1],n[2],n[3]),e+=n[1]):q=="s"?o==2||o==3?(y=y||b.getBBox(1),k.scale(n[1],n[o-1],y.x+y.width/2,y.y+y.height/2),h*=n[1],i*=n[o-1]):o==5&&(s?(w=t.x(n[3],n[4]),x=t.y(n[3],n[4]),k.scale(n[1],n[2],w,x)):k.scale(n[1],n[2],n[3],n[4]),h*=n[1],i*=n[2]):q=="m"&&o==7&&k.add(n[1],n[2],n[3],n[4],n[5],n[6]),j.dirtyT=1,b.matrix=k}b.matrix=k,j.sx=h,j.sy=i,j.deg=e,j.dx=f=k.e,j.dy=g=k.f,h==1&&i==1&&!e&&j.bbox?(j.bbox.x+=+f,j.bbox.y+=+g):j.dirtyT=1},b_=function(a){var b=a[0];switch(b.toLowerCase()){case"t":return[b,0,0];case"m":return[b,1,0,0,1,0,0];case"r":return a.length==4?[b,0,a[2],a[3]]:[b,0];case"s":return a.length==5?[b,1,1,a[3],a[4]]:a.length==3?[b,1,1]:[b,1]}},ca=a._equaliseTransform=function(b,c){c=r(c).replace(/\.{3}|\u2026/g,b),b=a.parseTransformString(b)||[],c=a.parseTransformString(c)||[];var d=x(b.length,c.length),e=[],f=[],g=0,h,i,j,k;for(;g<d;g++){j=b[g]||b_(c[g]),k=c[g]||b_(j);if(j[0]!=k[0]||j[0].toLowerCase()=="r"&&(j[2]!=k[2]||j[3]!=k[3])||j[0].toLowerCase()=="s"&&(j[3]!=k[3]||j[4]!=k[4]))return;e[g]=[],f[g]=[];for(h=0,i=x(j.length,k.length);h<i;h++)h in j&&(e[g][h]=j[h]),h in k&&(f[g][h]=k[h])}return{from:e,to:f}};a._getContainer=function(b,c,d,e){var f;f=e==null&&!a.is(b,"object")?h.doc.getElementById(b):b;if(f!=null){if(f.tagName)return c==null?{container:f,width:f.style.pixelWidth||f.offsetWidth,height:f.style.pixelHeight||f.offsetHeight}:{container:f,width:c,height:d};return{container:1,x:b,y:c,width:d,height:e}}},a.pathToRelative=bK,a._engine={},a.path2curve=bR,a.matrix=function(a,b,c,d,e,f){return new cb(a,b,c,d,e,f)},function(b){function d(a){var b=w.sqrt(c(a));a[0]&&(a[0]/=b),a[1]&&(a[1]/=b)}function c(a){return a[0]*a[0]+a[1]*a[1]}b.add=function(a,b,c,d,e,f){var g=[[],[],[]],h=[[this.a,this.c,this.e],[this.b,this.d,this.f],[0,0,1]],i=[[a,c,e],[b,d,f],[0,0,1]],j,k,l,m;a&&a instanceof cb&&(i=[[a.a,a.c,a.e],[a.b,a.d,a.f],[0,0,1]]);for(j=0;j<3;j++)for(k=0;k<3;k++){m=0;for(l=0;l<3;l++)m+=h[j][l]*i[l][k];g[j][k]=m}this.a=g[0][0],this.b=g[1][0],this.c=g[0][1],this.d=g[1][1],this.e=g[0][2],this.f=g[1][2]},b.invert=function(){var a=this,b=a.a*a.d-a.b*a.c;return new cb(a.d/b,-a.b/b,-a.c/b,a.a/b,(a.c*a.f-a.d*a.e)/b,(a.b*a.e-a.a*a.f)/b)},b.clone=function(){return new cb(this.a,this.b,this.c,this.d,this.e,this.f)},b.translate=function(a,b){this.add(1,0,0,1,a,b)},b.scale=function(a,b,c,d){b==null&&(b=a),(c||d)&&this.add(1,0,0,1,c,d),this.add(a,0,0,b,0,0),(c||d)&&this.add(1,0,0,1,-c,-d)},b.rotate=function(b,c,d){b=a.rad(b),c=c||0,d=d||0;var e=+w.cos(b).toFixed(9),f=+w.sin(b).toFixed(9);this.add(e,f,-f,e,c,d),this.add(1,0,0,1,-c,-d)},b.x=function(a,b){return a*this.a+b*this.c+this.e},b.y=function(a,b){return a*this.b+b*this.d+this.f},b.get=function(a){return+this[r.fromCharCode(97+a)].toFixed(4)},b.toString=function(){return a.svg?"matrix("+[this.get(0),this.get(1),this.get(2),this.get(3),this.get(4),this.get(5)].join()+")":[this.get(0),this.get(2),this.get(1),this.get(3),0,0].join()},b.toFilter=function(){return"progid:DXImageTransform.Microsoft.Matrix(M11="+this.get(0)+", M12="+this.get(2)+", M21="+this.get(1)+", M22="+this.get(3)+", Dx="+this.get(4)+", Dy="+this.get(5)+", sizingmethod='auto expand')"},b.offset=function(){return[this.e.toFixed(4),this.f.toFixed(4)]},b.split=function(){var b={};b.dx=this.e,b.dy=this.f;var e=[[this.a,this.c],[this.b,this.d]];b.scalex=w.sqrt(c(e[0])),d(e[0]),b.shear=e[0][0]*e[1][0]+e[0][1]*e[1][1],e[1]=[e[1][0]-e[0][0]*b.shear,e[1][1]-e[0][1]*b.shear],b.scaley=w.sqrt(c(e[1])),d(e[1]),b.shear/=b.scaley;var f=-e[0][1],g=e[1][1];g<0?(b.rotate=a.deg(w.acos(g)),f<0&&(b.rotate=360-b.rotate)):b.rotate=a.deg(w.asin(f)),b.isSimple=!+b.shear.toFixed(9)&&(b.scalex.toFixed(9)==b.scaley.toFixed(9)||!b.rotate),b.isSuperSimple=!+b.shear.toFixed(9)&&b.scalex.toFixed(9)==b.scaley.toFixed(9)&&!b.rotate,b.noRotation=!+b.shear.toFixed(9)&&!b.rotate;return b},b.toTransformString=function(a){var b=a||this[s]();if(b.isSimple){b.scalex=+b.scalex.toFixed(4),b.scaley=+b.scaley.toFixed(4),b.rotate=+b.rotate.toFixed(4);return(b.dx||b.dy?"t"+[b.dx,b.dy]:p)+(b.scalex!=1||b.scaley!=1?"s"+[b.scalex,b.scaley,0,0]:p)+(b.rotate?"r"+[b.rotate,0,0]:p)}return"m"+[this.get(0),this.get(1),this.get(2),this.get(3),this.get(4),this.get(5)]}}(cb.prototype);var cc=navigator.userAgent.match(/Version\/(.*?)\s/)||navigator.userAgent.match(/Chrome\/(\d+)/);navigator.vendor=="Apple Computer, Inc."&&(cc&&cc[1]<4||navigator.platform.slice(0,2)=="iP")||navigator.vendor=="Google Inc."&&cc&&cc[1]<8?k.safari=function(){var a=this.rect(-99,-99,this.width+99,this.height+99).attr({stroke:"none"});setTimeout(function(){a.remove()})}:k.safari=be;var cd=function(){this.returnValue=!1},ce=function(){return this.originalEvent.preventDefault()},cf=function(){this.cancelBubble=!0},cg=function(){return this.originalEvent.stopPropagation()},ch=function(){if(h.doc.addEventListener)return function(a,b,c,d){var e=o&&u[b]?u[b]:b,f=function(e){var f=h.doc.documentElement.scrollTop||h.doc.body.scrollTop,i=h.doc.documentElement.scrollLeft||h.doc.body.scrollLeft,j=e.clientX+i,k=e.clientY+f;if(o&&u[g](b))for(var l=0,m=e.targetTouches&&e.targetTouches.length;l<m;l++)if(e.targetTouches[l].target==a){var n=e;e=e.targetTouches[l],e.originalEvent=n,e.preventDefault=ce,e.stopPropagation=cg;break}return c.call(d,e,j,k)};a.addEventListener(e,f,!1);return function(){a.removeEventListener(e,f,!1);return!0}};if(h.doc.attachEvent)return function(a,b,c,d){var e=function(a){a=a||h.win.event;var b=h.doc.documentElement.scrollTop||h.doc.body.scrollTop,e=h.doc.documentElement.scrollLeft||h.doc.body.scrollLeft,f=a.clientX+e,g=a.clientY+b;a.preventDefault=a.preventDefault||cd,a.stopPropagation=a.stopPropagation||cf;return c.call(d,a,f,g)};a.attachEvent("on"+b,e);var f=function(){a.detachEvent("on"+b,e);return!0};return f}}(),ci=[],cj=function(a){var b=a.clientX,c=a.clientY,d=h.doc.documentElement.scrollTop||h.doc.body.scrollTop,e=h.doc.documentElement.scrollLeft||h.doc.body.scrollLeft,f,g=ci.length;while(g--){f=ci[g];if(o){var i=a.touches.length,j;while(i--){j=a.touches[i];if(j.identifier==f.el._drag.id){b=j.clientX,c=j.clientY,(a.originalEvent?a.originalEvent:a).preventDefault();break}}}else a.preventDefault();var k=f.el.node,l,m=k.nextSibling,n=k.parentNode,p=k.style.display;h.win.opera&&n.removeChild(k),k.style.display="none",l=f.el.paper.getElementByPoint(b,c),k.style.display=p,h.win.opera&&(m?n.insertBefore(k,m):n.appendChild(k)),l&&eve("raphael.drag.over."+f.el.id,f.el,l),b+=e,c+=d,eve("raphael.drag.move."+f.el.id,f.move_scope||f.el,b-f.el._drag.x,c-f.el._drag.y,b,c,a)}},ck=function(b){a.unmousemove(cj).unmouseup(ck);var c=ci.length,d;while(c--)d=ci[c],d.el._drag={},eve("raphael.drag.end."+d.el.id,d.end_scope||d.start_scope||d.move_scope||d.el,b);ci=[]},cl=a.el={};for(var cm=t.length;cm--;)(function(b){a[b]=cl[b]=function(c,d){a.is(c,"function")&&(this.events=this.events||[],this.events.push({name:b,f:c,unbind:ch(this.shape||this.node||h.doc,b,c,d||this)}));return this},a["un"+b]=cl["un"+b]=function(a){var c=this.events||[],d=c.length;while(d--)if(c[d].name==b&&c[d].f==a){c[d].unbind(),c.splice(d,1),!c.length&&delete this.events;return this}return this}})(t[cm]);cl.data=function(b,c){var d=bb[this.id]=bb[this.id]||{};if(arguments.length==1){if(a.is(b,"object")){for(var e in b)b[g](e)&&this.data(e,b[e]);return this}eve("raphael.data.get."+this.id,this,d[b],b);return d[b]}d[b]=c,eve("raphael.data.set."+this.id,this,c,b);return this},cl.removeData=function(a){a==null?bb[this.id]={}:bb[this.id]&&delete bb[this.id][a];return this},cl.hover=function(a,b,c,d){return this.mouseover(a,c).mouseout(b,d||c)},cl.unhover=function(a,b){return this.unmouseover(a).unmouseout(b)};var cn=[];cl.drag=function(b,c,d,e,f,g){function i(i){(i.originalEvent||i).preventDefault();var j=h.doc.documentElement.scrollTop||h.doc.body.scrollTop,k=h.doc.documentElement.scrollLeft||h.doc.body.scrollLeft;this._drag.x=i.clientX+k,this._drag.y=i.clientY+j,this._drag.id=i.identifier,!ci.length&&a.mousemove(cj).mouseup(ck),ci.push({el:this,move_scope:e,start_scope:f,end_scope:g}),c&&eve.on("raphael.drag.start."+this.id,c),b&&eve.on("raphael.drag.move."+this.id,b),d&&eve.on("raphael.drag.end."+this.id,d),eve("raphael.drag.start."+this.id,f||e||this,i.clientX+k,i.clientY+j,i)}this._drag={},cn.push({el:this,start:i}),this.mousedown(i);return this},cl.onDragOver=function(a){a?eve.on("raphael.drag.over."+this.id,a):eve.unbind("raphael.drag.over."+this.id)},cl.undrag=function(){var b=cn.length;while(b--)cn[b].el==this&&(this.unmousedown(cn[b].start),cn.splice(b,1),eve.unbind("raphael.drag.*."+this.id));!cn.length&&a.unmousemove(cj).unmouseup(ck)},k.circle=function(b,c,d){var e=a._engine.circle(this,b||0,c||0,d||0);this.__set__&&this.__set__.push(e);return e},k.rect=function(b,c,d,e,f){var g=a._engine.rect(this,b||0,c||0,d||0,e||0,f||0);this.__set__&&this.__set__.push(g);return g},k.ellipse=function(b,c,d,e){var f=a._engine.ellipse(this,b||0,c||0,d||0,e||0);this.__set__&&this.__set__.push(f);return f},k.path=function(b){b&&!a.is(b,D)&&!a.is(b[0],E)&&(b+=p);var c=a._engine.path(a.format[m](a,arguments),this);this.__set__&&this.__set__.push(c);return c},k.image=function(b,c,d,e,f){var g=a._engine.image(this,b||"about:blank",c||0,d||0,e||0,f||0);this.__set__&&this.__set__.push(g);return g},k.text=function(b,c,d){var e=a._engine.text(this,b||0,c||0,r(d));this.__set__&&this.__set__.push(e);return e},k.set=function(b){!a.is(b,"array")&&(b=Array.prototype.splice.call(arguments,0,arguments.length));var c=new cG(b);this.__set__&&this.__set__.push(c);return c},k.setStart=function(a){this.__set__=a||this.set()},k.setFinish=function(a){var b=this.__set__;delete this.__set__;return b},k.setSize=function(b,c){return a._engine.setSize.call(this,b,c)},k.setViewBox=function(b,c,d,e,f){return a._engine.setViewBox.call(this,b,c,d,e,f)},k.top=k.bottom=null,k.raphael=a;var co=function(a){var b=a.getBoundingClientRect(),c=a.ownerDocument,d=c.body,e=c.documentElement,f=e.clientTop||d.clientTop||0,g=e.clientLeft||d.clientLeft||0,i=b.top+(h.win.pageYOffset||e.scrollTop||d.scrollTop)-f,j=b.left+(h.win.pageXOffset||e.scrollLeft||d.scrollLeft)-g;return{y:i,x:j}};k.getElementByPoint=function(a,b){var c=this,d=c.canvas,e=h.doc.elementFromPoint(a,b);if(h.win.opera&&e.tagName=="svg"){var f=co(d),g=d.createSVGRect();g.x=a-f.x,g.y=b-f.y,g.width=g.height=1;var i=d.getIntersectionList(g,null);i.length&&(e=i[i.length-1])}if(!e)return null;while(e.parentNode&&e!=d.parentNode&&!e.raphael)e=e.parentNode;e==c.canvas.parentNode&&(e=d),e=e&&e.raphael?c.getById(e.raphaelid):null;return e},k.getById=function(a){var b=this.bottom;while(b){if(b.id==a)return b;b=b.next}return null},k.forEach=function(a,b){var c=this.bottom;while(c){if(a.call(b,c)===!1)return this;c=c.next}return this},k.getElementsByPoint=function(a,b){var c=this.set();this.forEach(function(d){d.isPointInside(a,b)&&c.push(d)});return c},cl.isPointInside=function(b,c){var d=this.realPath=this.realPath||bi[this.type](this);return a.isPointInsidePath(d,b,c)},cl.getBBox=function(a){if(this.removed)return{};var b=this._;if(a){if(b.dirty||!b.bboxwt)this.realPath=bi[this.type](this),b.bboxwt=bI(this.realPath),b.bboxwt.toString=cq,b.dirty=0;return b.bboxwt}if(b.dirty||b.dirtyT||!b.bbox){if(b.dirty||!this.realPath)b.bboxwt=0,this.realPath=bi[this.type](this);b.bbox=bI(bj(this.realPath,this.matrix)),b.bbox.toString=cq,b.dirty=b.dirtyT=0}return b.bbox},cl.clone=function(){if(this.removed)return null;var a=this.paper[this.type]().attr(this.attr());this.__set__&&this.__set__.push(a);return a},cl.glow=function(a){if(this.type=="text")return null;a=a||{};var b={width:(a.width||10)+(+this.attr("stroke-width")||1),fill:a.fill||!1,opacity:a.opacity||.5,offsetx:a.offsetx||0,offsety:a.offsety||0,color:a.color||"#000"},c=b.width/2,d=this.paper,e=d.set(),f=this.realPath||bi[this.type](this);f=this.matrix?bj(f,this.matrix):f;for(var g=1;g<c+1;g++)e.push(d.path(f).attr({stroke:b.color,fill:b.fill?b.color:"none","stroke-linejoin":"round","stroke-linecap":"round","stroke-width":+(b.width/c*g).toFixed(3),opacity:+(b.opacity/c).toFixed(3)}));return e.insertBefore(this).translate(b.offsetx,b.offsety)};var cr={},cs=function(b,c,d,e,f,g,h,i,j){return j==null?bB(b,c,d,e,f,g,h,i):a.findDotsAtSegment(b,c,d,e,f,g,h,i,bC(b,c,d,e,f,g,h,i,j))},ct=function(b,c){return function(d,e,f){d=bR(d);var g,h,i,j,k="",l={},m,n=0;for(var o=0,p=d.length;o<p;o++){i=d[o];if(i[0]=="M")g=+i[1],h=+i[2];else{j=cs(g,h,i[1],i[2],i[3],i[4],i[5],i[6]);if(n+j>e){if(c&&!l.start){m=cs(g,h,i[1],i[2],i[3],i[4],i[5],i[6],e-n),k+=["C"+m.start.x,m.start.y,m.m.x,m.m.y,m.x,m.y];if(f)return k;l.start=k,k=["M"+m.x,m.y+"C"+m.n.x,m.n.y,m.end.x,m.end.y,i[5],i[6]].join(),n+=j,g=+i[5],h=+i[6];continue}if(!b&&!c){m=cs(g,h,i[1],i[2],i[3],i[4],i[5],i[6],e-n);return{x:m.x,y:m.y,alpha:m.alpha}}}n+=j,g=+i[5],h=+i[6]}k+=i.shift()+i}l.end=k,m=b?n:c?l:a.findDotsAtSegment(g,h,i[0],i[1],i[2],i[3],i[4],i[5],1),m.alpha&&(m={x:m.x,y:m.y,alpha:m.alpha});return m}},cu=ct(1),cv=ct(),cw=ct(0,1);a.getTotalLength=cu,a.getPointAtLength=cv,a.getSubpath=function(a,b,c){if(this.getTotalLength(a)-c<1e-6)return cw(a,b).end;var d=cw(a,c,1);return b?cw(d,b).end:d},cl.getTotalLength=function(){if(this.type=="path"){if(this.node.getTotalLength)return this.node.getTotalLength();return cu(this.attrs.path)}},cl.getPointAtLength=function(a){if(this.type=="path")return cv(this.attrs.path,a)},cl.getSubpath=function(b,c){if(this.type=="path")return a.getSubpath(this.attrs.path,b,c)};var cx=a.easing_formulas={linear:function(a){return a},"<":function(a){return A(a,1.7)},">":function(a){return A(a,.48)},"<>":function(a){var b=.48-a/1.04,c=w.sqrt(.1734+b*b),d=c-b,e=A(z(d),1/3)*(d<0?-1:1),f=-c-b,g=A(z(f),1/3)*(f<0?-1:1),h=e+g+.5;return(1-h)*3*h*h+h*h*h},backIn:function(a){var b=1.70158;return a*a*((b+1)*a-b)},backOut:function(a){a=a-1;var b=1.70158;return a*a*((b+1)*a+b)+1},elastic:function(a){if(a==!!a)return a;return A(2,-10*a)*w.sin((a-.075)*2*B/.3)+1},bounce:function(a){var b=7.5625,c=2.75,d;a<1/c?d=b*a*a:a<2/c?(a-=1.5/c,d=b*a*a+.75):a<2.5/c?(a-=2.25/c,d=b*a*a+.9375):(a-=2.625/c,d=b*a*a+.984375);return d}};cx.easeIn=cx["ease-in"]=cx["<"],cx.easeOut=cx["ease-out"]=cx[">"],cx.easeInOut=cx["ease-in-out"]=cx["<>"],cx["back-in"]=cx.backIn,cx["back-out"]=cx.backOut;var cy=[],cz=window.requestAnimationFrame||window.webkitRequestAnimationFrame||window.mozRequestAnimationFrame||window.oRequestAnimationFrame||window.msRequestAnimationFrame||function(a){setTimeout(a,16)},cA=function(){var b=+(new Date),c=0;for(;c<cy.length;c++){var d=cy[c];if(d.el.removed||d.paused)continue;var e=b-d.start,f=d.ms,h=d.easing,i=d.from,j=d.diff,k=d.to,l=d.t,m=d.el,o={},p,r={},s;d.initstatus?(e=(d.initstatus*d.anim.top-d.prev)/(d.percent-d.prev)*f,d.status=d.initstatus,delete d.initstatus,d.stop&&cy.splice(c--,1)):d.status=(d.prev+(d.percent-d.prev)*(e/f))/d.anim.top;if(e<0)continue;if(e<f){var t=h(e/f);for(var u in i)if(i[g](u)){switch(U[u]){case C:p=+i[u]+t*f*j[u];break;case"colour":p="rgb("+[cB(O(i[u].r+t*f*j[u].r)),cB(O(i[u].g+t*f*j[u].g)),cB(O(i[u].b+t*f*j[u].b))].join(",")+")";break;case"path":p=[];for(var v=0,w=i[u].length;v<w;v++){p[v]=[i[u][v][0]];for(var x=1,y=i[u][v].length;x<y;x++)p[v][x]=+i[u][v][x]+t*f*j[u][v][x];p[v]=p[v].join(q)}p=p.join(q);break;case"transform":if(j[u].real){p=[];for(v=0,w=i[u].length;v<w;v++){p[v]=[i[u][v][0]];for(x=1,y=i[u][v].length;x<y;x++)p[v][x]=i[u][v][x]+t*f*j[u][v][x]}}else{var z=function(a){return+i[u][a]+t*f*j[u][a]};p=[["m",z(0),z(1),z(2),z(3),z(4),z(5)]]}break;case"csv":if(u=="clip-rect"){p=[],v=4;while(v--)p[v]=+i[u][v]+t*f*j[u][v]}break;default:var A=[][n](i[u]);p=[],v=m.paper.customAttributes[u].length;while(v--)p[v]=+A[v]+t*f*j[u][v]}o[u]=p}m.attr(o),function(a,b,c){setTimeout(function(){eve("raphael.anim.frame."+a,b,c)})}(m.id,m,d.anim)}else{(function(b,c,d){setTimeout(function(){eve("raphael.anim.frame."+c.id,c,d),eve("raphael.anim.finish."+c.id,c,d),a.is(b,"function")&&b.call(c)})})(d.callback,m,d.anim),m.attr(k),cy.splice(c--,1);if(d.repeat>1&&!d.next){for(s in k)k[g](s)&&(r[s]=d.totalOrigin[s]);d.el.attr(r),cE(d.anim,d.el,d.anim.percents[0],null,d.totalOrigin,d.repeat-1)}d.next&&!d.stop&&cE(d.anim,d.el,d.next,null,d.totalOrigin,d.repeat)}}a.svg&&m&&m.paper&&m.paper.safari(),cy.length&&cz(cA)},cB=function(a){return a>255?255:a<0?0:a};cl.animateWith=function(b,c,d,e,f,g){var h=this;if(h.removed){g&&g.call(h);return h}var i=d instanceof cD?d:a.animation(d,e,f,g),j,k;cE(i,h,i.percents[0],null,h.attr());for(var l=0,m=cy.length;l<m;l++)if(cy[l].anim==c&&cy[l].el==b){cy[m-1].start=cy[l].start;break}return h},cl.onAnimation=function(a){a?eve.on("raphael.anim.frame."+this.id,a):eve.unbind("raphael.anim.frame."+this.id);return this},cD.prototype.delay=function(a){var b=new cD(this.anim,this.ms);b.times=this.times,b.del=+a||0;return b},cD.prototype.repeat=function(a){var b=new cD(this.anim,this.ms);b.del=this.del,b.times=w.floor(x(a,0))||1;return b},a.animation=function(b,c,d,e){if(b instanceof cD)return b;if(a.is(d,"function")||!d)e=e||d||null,d=null;b=Object(b),c=+c||0;var f={},h,i;for(i in b)b[g](i)&&Q(i)!=i&&Q(i)+"%"!=i&&(h=!0,f[i]=b[i]);if(!h)return new cD(b,c);d&&(f.easing=d),e&&(f.callback=e);return new cD({100:f},c)},cl.animate=function(b,c,d,e){var f=this;if(f.removed){e&&e.call(f);return f}var g=b instanceof cD?b:a.animation(b,c,d,e);cE(g,f,g.percents[0],null,f.attr());return f},cl.setTime=function(a,b){a&&b!=null&&this.status(a,y(b,a.ms)/a.ms);return this},cl.status=function(a,b){var c=[],d=0,e,f;if(b!=null){cE(a,this,-1,y(b,1));return this}e=cy.length;for(;d<e;d++){f=cy[d];if(f.el.id==this.id&&(!a||f.anim==a)){if(a)return f.status;c.push({anim:f.anim,status:f.status})}}if(a)return 0;return c},cl.pause=function(a){for(var b=0;b<cy.length;b++)cy[b].el.id==this.id&&(!a||cy[b].anim==a)&&eve("raphael.anim.pause."+this.id,this,cy[b].anim)!==!1&&(cy[b].paused=!0);return this},cl.resume=function(a){for(var b=0;b<cy.length;b++)if(cy[b].el.id==this.id&&(!a||cy[b].anim==a)){var c=cy[b];eve("raphael.anim.resume."+this.id,this,c.anim)!==!1&&(delete c.paused,this.status(c.anim,c.status))}return this},cl.stop=function(a){for(var b=0;b<cy.length;b++)cy[b].el.id==this.id&&(!a||cy[b].anim==a)&&eve("raphael.anim.stop."+this.id,this,cy[b].anim)!==!1&&cy.splice(b--,1);return this},eve.on("raphael.remove",cF),eve.on("raphael.clear",cF),cl.toString=function(){return"Raphaël’s object"};var cG=function(a){this.items=[],this.length=0,this.type="set";if(a)for(var b=0,c=a.length;b<c;b++)a[b]&&(a[b].constructor==cl.constructor||a[b].constructor==cG)&&(this[this.items.length]=this.items[this.items.length]=a[b],this.length++)},cH=cG.prototype;cH.push=function(){var a,b;for(var c=0,d=arguments.length;c<d;c++)a=arguments[c],a&&(a.constructor==cl.constructor||a.constructor==cG)&&(b=this.items.length,this[b]=this.items[b]=a,this.length++);return this},cH.pop=function(){this.length&&delete this[this.length--];return this.items.pop()},cH.forEach=function(a,b){for(var c=0,d=this.items.length;c<d;c++)if(a.call(b,this.items[c],c)===!1)return this;return this};for(var cI in cl)cl[g](cI)&&(cH[cI]=function(a){return function(){var b=arguments;return this.forEach(function(c){c[a][m](c,b)})}}(cI));cH.attr=function(b,c){if(b&&a.is(b,E)&&a.is(b[0],"object"))for(var d=0,e=b.length;d<e;d++)this.items[d].attr(b[d]);else for(var f=0,g=this.items.length;f<g;f++)this.items[f].attr(b,c);return this},cH.clear=function(){while(this.length)this.pop()},cH.splice=function(a,b,c){a=a<0?x(this.length+a,0):a,b=x(0,y(this.length-a,b));var d=[],e=[],f=[],g;for(g=2;g<arguments.length;g++)f.push(arguments[g]);for(g=0;g<b;g++)e.push(this[a+g]);for(;g<this.length-a;g++)d.push(this[a+g]);var h=f.length;for(g=0;g<h+d.length;g++)this.items[a+g]=this[a+g]=g<h?f[g]:d[g-h];g=this.items.length=this.length-=b-h;while(this[g])delete this[g++];return new cG(e)},cH.exclude=function(a){for(var b=0,c=this.length;b<c;b++)if(this[b]==a){this.splice(b,1);return!0}},cH.animate=function(b,c,d,e){(a.is(d,"function")||!d)&&(e=d||null);var f=this.items.length,g=f,h,i=this,j;if(!f)return this;e&&(j=function(){!--f&&e.call(i)}),d=a.is(d,D)?d:j;var k=a.animation(b,c,d,j);h=this.items[--g].animate(k);while(g--)this.items[g]&&!this.items[g].removed&&this.items[g].animateWith(h,k,k);return this},cH.insertAfter=function(a){var b=this.items.length;while(b--)this.items[b].insertAfter(a);return this},cH.getBBox=function(){var a=[],b=[],c=[],d=[];for(var e=this.items.length;e--;)if(!this.items[e].removed){var f=this.items[e].getBBox();a.push(f.x),b.push(f.y),c.push(f.x+f.width),d.push(f.y+f.height)}a=y[m](0,a),b=y[m](0,b),c=x[m](0,c),d=x[m](0,d);return{x:a,y:b,x2:c,y2:d,width:c-a,height:d-b}},cH.clone=function(a){a=new cG;for(var b=0,c=this.items.length;b<c;b++)a.push(this.items[b].clone());return a},cH.toString=function(){return"Raphaël‘s set"},a.registerFont=function(a){if(!a.face)return a;this.fonts=this.fonts||{};var b={w:a.w,face:{},glyphs:{}},c=a.face["font-family"];for(var d in a.face)a.face[g](d)&&(b.face[d]=a.face[d]);this.fonts[c]?this.fonts[c].push(b):this.fonts[c]=[b];if(!a.svg){b.face["units-per-em"]=R(a.face["units-per-em"],10);for(var e in a.glyphs)if(a.glyphs[g](e)){var f=a.glyphs[e];b.glyphs[e]={w:f.w,k:{},d:f.d&&"M"+f.d.replace(/[mlcxtrv]/g,function(a){return{l:"L",c:"C",x:"z",t:"m",r:"l",v:"c"}[a]||"M"})+"z"};if(f.k)for(var h in f.k)f[g](h)&&(b.glyphs[e].k[h]=f.k[h])}}return a},k.getFont=function(b,c,d,e){e=e||"normal",d=d||"normal",c=+c||{normal:400,bold:700,lighter:300,bolder:800}[c]||400;if(!!a.fonts){var f=a.fonts[b];if(!f){var h=new RegExp("(^|\\s)"+b.replace(/[^\w\d\s+!~.:_-]/g,p)+"(\\s|$)","i");for(var i in a.fonts)if(a.fonts[g](i)&&h.test(i)){f=a.fonts[i];break}}var j;if(f)for(var k=0,l=f.length;k<l;k++){j=f[k];if(j.face["font-weight"]==c&&(j.face["font-style"]==d||!j.face["font-style"])&&j.face["font-stretch"]==e)break}return j}},k.print=function(b,d,e,f,g,h,i){h=h||"middle",i=x(y(i||0,1),-1);var j=r(e)[s](p),k=0,l=0,m=p,n;a.is(f,e)&&(f=this.getFont(f));if(f){n=(g||16)/f.face["units-per-em"];var o=f.face.bbox[s](c),q=+o[0],t=o[3]-o[1],u=0,v=+o[1]+(h=="baseline"?t+ +f.face.descent:t/2);for(var w=0,z=j.length;w<z;w++){if(j[w]=="\n")k=0,B=0,l=0,u+=t;else{var A=l&&f.glyphs[j[w-1]]||{},B=f.glyphs[j[w]];k+=l?(A.w||f.w)+(A.k&&A.k[j[w]]||0)+f.w*i:0,l=1}B&&B.d&&(m+=a.transformPath(B.d,["t",k*n,u*n,"s",n,n,q,v,"t",(b-q)/n,(d-v)/n]))}}return this.path(m).attr({fill:"#000",stroke:"none"})},k.add=function(b){if(a.is(b,"array")){var c=this.set(),e=0,f=b.length,h;for(;e<f;e++)h=b[e]||{},d[g](h.type)&&c.push(this[h.type]().attr(h))}return c},a.format=function(b,c){var d=a.is(c,E)?[0][n](c):arguments;b&&a.is(b,D)&&d.length-1&&(b=b.replace(e,function(a,b){return d[++b]==null?p:d[b]}));return b||p},a.fullfill=function(){var a=/\{([^\}]+)\}/g,b=/(?:(?:^|\.)(.+?)(?=\[|\.|$|\()|\[('|")(.+?)\2\])(\(\))?/g,c=function(a,c,d){var e=d;c.replace(b,function(a,b,c,d,f){b=b||d,e&&(b in e&&(e=e[b]),typeof e=="function"&&f&&(e=e()))}),e=(e==null||e==d?a:e)+"";return e};return function(b,d){return String(b).replace(a,function(a,b){return c(a,b,d)})}}(),a.ninja=function(){i.was?h.win.Raphael=i.is:delete Raphael;return a},a.st=cH,function(b,c,d){function e(){/in/.test(b.readyState)?setTimeout(e,9):a.eve("raphael.DOMload")}b.readyState==null&&b.addEventListener&&(b.addEventListener(c,d=function(){b.removeEventListener(c,d,!1),b.readyState="complete"},!1),b.readyState="loading"),e()}(document,"DOMContentLoaded"),i.was?h.win.Raphael=a:Raphael=a,eve.on("raphael.DOMload",function(){b=!0})}(),window.Raphael.svg&&function(a){var b="hasOwnProperty",c=String,d=parseFloat,e=parseInt,f=Math,g=f.max,h=f.abs,i=f.pow,j=/[, ]+/,k=a.eve,l="",m=" ",n="http://www.w3.org/1999/xlink",o={block:"M5,0 0,2.5 5,5z",classic:"M5,0 0,2.5 5,5 3.5,3 3.5,2z",diamond:"M2.5,0 5,2.5 2.5,5 0,2.5z",open:"M6,1 1,3.5 6,6",oval:"M2.5,0A2.5,2.5,0,0,1,2.5,5 2.5,2.5,0,0,1,2.5,0z"},p={};a.toString=function(){return"Your browser supports SVG.\nYou are running Raphaël "+this.version};var q=function(d,e){if(e){typeof d=="string"&&(d=q(d));for(var f in e)e[b](f)&&(f.substring(0,6)=="xlink:"?d.setAttributeNS(n,f.substring(6),c(e[f])):d.setAttribute(f,c(e[f])))}else d=a._g.doc.createElementNS("http://www.w3.org/2000/svg",d),d.style&&(d.style.webkitTapHighlightColor="rgba(0,0,0,0)");return d},r=function(b,e){var j="linear",k=b.id+e,m=.5,n=.5,o=b.node,p=b.paper,r=o.style,s=a._g.doc.getElementById(k);if(!s){e=c(e).replace(a._radial_gradient,function(a,b,c){j="radial";if(b&&c){m=d(b),n=d(c);var e=(n>.5)*2-1;i(m-.5,2)+i(n-.5,2)>.25&&(n=f.sqrt(.25-i(m-.5,2))*e+.5)&&n!=.5&&(n=n.toFixed(5)-1e-5*e)}return l}),e=e.split(/\s*\-\s*/);if(j=="linear"){var t=e.shift();t=-d(t);if(isNaN(t))return null;var u=[0,0,f.cos(a.rad(t)),f.sin(a.rad(t))],v=1/(g(h(u[2]),h(u[3]))||1);u[2]*=v,u[3]*=v,u[2]<0&&(u[0]=-u[2],u[2]=0),u[3]<0&&(u[1]=-u[3],u[3]=0)}var w=a._parseDots(e);if(!w)return null;k=k.replace(/[\(\)\s,\xb0#]/g,"_"),b.gradient&&k!=b.gradient.id&&(p.defs.removeChild(b.gradient),delete b.gradient);if(!b.gradient){s=q(j+"Gradient",{id:k}),b.gradient=s,q(s,j=="radial"?{fx:m,fy:n}:{x1:u[0],y1:u[1],x2:u[2],y2:u[3],gradientTransform:b.matrix.invert()}),p.defs.appendChild(s);for(var x=0,y=w.length;x<y;x++)s.appendChild(q("stop",{offset:w[x].offset?w[x].offset:x?"100%":"0%","stop-color":w[x].color||"#fff"}))}}q(o,{fill:"url(#"+k+")",opacity:1,"fill-opacity":1}),r.fill=l,r.opacity=1,r.fillOpacity=1;return 1},s=function(a){var b=a.getBBox(1);q(a.pattern,{patternTransform:a.matrix.invert()+" translate("+b.x+","+b.y+")"})},t=function(d,e,f){if(d.type=="path"){var g=c(e).toLowerCase().split("-"),h=d.paper,i=f?"end":"start",j=d.node,k=d.attrs,m=k["stroke-width"],n=g.length,r="classic",s,t,u,v,w,x=3,y=3,z=5;while(n--)switch(g[n]){case"block":case"classic":case"oval":case"diamond":case"open":case"none":r=g[n];break;case"wide":y=5;break;case"narrow":y=2;break;case"long":x=5;break;case"short":x=2}r=="open"?(x+=2,y+=2,z+=2,u=1,v=f?4:1,w={fill:"none",stroke:k.stroke}):(v=u=x/2,w={fill:k.stroke,stroke:"none"}),d._.arrows?f?(d._.arrows.endPath&&p[d._.arrows.endPath]--,d._.arrows.endMarker&&p[d._.arrows.endMarker]--):(d._.arrows.startPath&&p[d._.arrows.startPath]--,d._.arrows.startMarker&&p[d._.arrows.startMarker]--):d._.arrows={};if(r!="none"){var A="raphael-marker-"+r,B="raphael-marker-"+i+r+x+y;a._g.doc.getElementById(A)?p[A]++:(h.defs.appendChild(q(q("path"),{"stroke-linecap":"round",d:o[r],id:A})),p[A]=1);var C=a._g.doc.getElementById(B),D;C?(p[B]++,D=C.getElementsByTagName("use")[0]):(C=q(q("marker"),{id:B,markerHeight:y,markerWidth:x,orient:"auto",refX:v,refY:y/2}),D=q(q("use"),{"xlink:href":"#"+A,transform:(f?"rotate(180 "+x/2+" "+y/2+") ":l)+"scale("+x/z+","+y/z+")","stroke-width":(1/((x/z+y/z)/2)).toFixed(4)}),C.appendChild(D),h.defs.appendChild(C),p[B]=1),q(D,w);var F=u*(r!="diamond"&&r!="oval");f?(s=d._.arrows.startdx*m||0,t=a.getTotalLength(k.path)-F*m):(s=F*m,t=a.getTotalLength(k.path)-(d._.arrows.enddx*m||0)),w={},w["marker-"+i]="url(#"+B+")";if(t||s)w.d=Raphael.getSubpath(k.path,s,t);q(j,w),d._.arrows[i+"Path"]=A,d._.arrows[i+"Marker"]=B,d._.arrows[i+"dx"]=F,d._.arrows[i+"Type"]=r,d._.arrows[i+"String"]=e}else f?(s=d._.arrows.startdx*m||0,t=a.getTotalLength(k.path)-s):(s=0,t=a.getTotalLength(k.path)-(d._.arrows.enddx*m||0)),d._.arrows[i+"Path"]&&q(j,{d:Raphael.getSubpath(k.path,s,t)}),delete d._.arrows[i+"Path"],delete d._.arrows[i+"Marker"],delete d._.arrows[i+"dx"],delete d._.arrows[i+"Type"],delete d._.arrows[i+"String"];for(w in p)if(p[b](w)&&!p[w]){var G=a._g.doc.getElementById(w);G&&G.parentNode.removeChild(G)}}},u={"":[0],none:[0],"-":[3,1],".":[1,1],"-.":[3,1,1,1],"-..":[3,1,1,1,1,1],". ":[1,3],"- ":[4,3],"--":[8,3],"- .":[4,3,1,3],"--.":[8,3,1,3],"--..":[8,3,1,3,1,3]},v=function(a,b,d){b=u[c(b).toLowerCase()];if(b){var e=a.attrs["stroke-width"]||"1",f={round:e,square:e,butt:0}[a.attrs["stroke-linecap"]||d["stroke-linecap"]]||0,g=[],h=b.length;while(h--)g[h]=b[h]*e+(h%2?1:-1)*f;q(a.node,{"stroke-dasharray":g.join(",")})}},w=function(d,f){var i=d.node,k=d.attrs,m=i.style.visibility;i.style.visibility="hidden";for(var o in f)if(f[b](o)){if(!a._availableAttrs[b](o))continue;var p=f[o];k[o]=p;switch(o){case"blur":d.blur(p);break;case"href":case"title":case"target":var u=i.parentNode;if(u.tagName.toLowerCase()!="a"){var w=q("a");u.insertBefore(w,i),w.appendChild(i),u=w}o=="target"?u.setAttributeNS(n,"show",p=="blank"?"new":p):u.setAttributeNS(n,o,p);break;case"cursor":i.style.cursor=p;break;case"transform":d.transform(p);break;case"arrow-start":t(d,p);break;case"arrow-end":t(d,p,1);break;case"clip-rect":var x=c(p).split(j);if(x.length==4){d.clip&&d.clip.parentNode.parentNode.removeChild(d.clip.parentNode);var z=q("clipPath"),A=q("rect");z.id=a.createUUID(),q(A,{x:x[0],y:x[1],width:x[2],height:x[3]}),z.appendChild(A),d.paper.defs.appendChild(z),q(i,{"clip-path":"url(#"+z.id+")"}),d.clip=A}if(!p){var B=i.getAttribute("clip-path");if(B){var C=a._g.doc.getElementById(B.replace(/(^url\(#|\)$)/g,l));C&&C.parentNode.removeChild(C),q(i,{"clip-path":l}),delete d.clip}}break;case"path":d.type=="path"&&(q(i,{d:p?k.path=a._pathToAbsolute(p):"M0,0"}),d._.dirty=1,d._.arrows&&("startString"in d._.arrows&&t(d,d._.arrows.startString),"endString"in d._.arrows&&t(d,d._.arrows.endString,1)));break;case"width":i.setAttribute(o,p),d._.dirty=1;if(k.fx)o="x",p=k.x;else break;case"x":k.fx&&(p=-k.x-(k.width||0));case"rx":if(o=="rx"&&d.type=="rect")break;case"cx":i.setAttribute(o,p),d.pattern&&s(d),d._.dirty=1;break;case"height":i.setAttribute(o,p),d._.dirty=1;if(k.fy)o="y",p=k.y;else break;case"y":k.fy&&(p=-k.y-(k.height||0));case"ry":if(o=="ry"&&d.type=="rect")break;case"cy":i.setAttribute(o,p),d.pattern&&s(d),d._.dirty=1;break;case"r":d.type=="rect"?q(i,{rx:p,ry:p}):i.setAttribute(o,p),d._.dirty=1;break;case"src":d.type=="image"&&i.setAttributeNS(n,"href",p);break;case"stroke-width":if(d._.sx!=1||d._.sy!=1)p/=g(h(d._.sx),h(d._.sy))||1;d.paper._vbSize&&(p*=d.paper._vbSize),i.setAttribute(o,p),k["stroke-dasharray"]&&v(d,k["stroke-dasharray"],f),d._.arrows&&("startString"in d._.arrows&&t(d,d._.arrows.startString),"endString"in d._.arrows&&t(d,d._.arrows.endString,1));break;case"stroke-dasharray":v(d,p,f);break;case"fill":var D=c(p).match(a._ISURL);if(D){z=q("pattern");var F=q("image");z.id=a.createUUID(),q(z,{x:0,y:0,patternUnits:"userSpaceOnUse",height:1,width:1}),q(F,{x:0,y:0,"xlink:href":D[1]}),z.appendChild(F),function(b){a._preload(D[1],function(){var a=this.offsetWidth,c=this.offsetHeight;q(b,{width:a,height:c}),q(F,{width:a,height:c}),d.paper.safari()})}(z),d.paper.defs.appendChild(z),q(i,{fill:"url(#"+z.id+")"}),d.pattern=z,d.pattern&&s(d);break}var G=a.getRGB(p);if(!G.error)delete f.gradient,delete k.gradient,!a.is(k.opacity,"undefined")&&a.is(f.opacity,"undefined")&&q(i,{opacity:k.opacity}),!a.is(k["fill-opacity"],"undefined")&&a.is(f["fill-opacity"],"undefined")&&q(i,{"fill-opacity":k["fill-opacity"]});else if((d.type=="circle"||d.type=="ellipse"||c(p).charAt()!="r")&&r(d,p)){if("opacity"in k||"fill-opacity"in k){var H=a._g.doc.getElementById(i.getAttribute("fill").replace(/^url\(#|\)$/g,l));if(H){var I=H.getElementsByTagName("stop");q(I[I.length-1],{"stop-opacity":("opacity"in k?k.opacity:1)*("fill-opacity"in k?k["fill-opacity"]:1)})}}k.gradient=p,k.fill="none";break}G[b]("opacity")&&q(i,{"fill-opacity":G.opacity>1?G.opacity/100:G.opacity});case"stroke":G=a.getRGB(p),i.setAttribute(o,G.hex),o=="stroke"&&G[b]("opacity")&&q(i,{"stroke-opacity":G.opacity>1?G.opacity/100:G.opacity}),o=="stroke"&&d._.arrows&&("startString"in d._.arrows&&t(d,d._.arrows.startString),"endString"in d._.arrows&&t(d,d._.arrows.endString,1));break;case"gradient":(d.type=="circle"||d.type=="ellipse"||c(p).charAt()!="r")&&r(d,p);break;case"opacity":k.gradient&&!k[b]("stroke-opacity")&&q(i,{"stroke-opacity":p>1?p/100:p});case"fill-opacity":if(k.gradient){H=a._g.doc.getElementById(i.getAttribute("fill").replace(/^url\(#|\)$/g,l)),H&&(I=H.getElementsByTagName("stop"),q(I[I.length-1],{"stop-opacity":p}));break};default:o=="font-size"&&(p=e(p,10)+"px");var J=o.replace(/(\-.)/g,function(a){return a.substring(1).toUpperCase()});i.style[J]=p,d._.dirty=1,i.setAttribute(o,p)}}y(d,f),i.style.visibility=m},x=1.2,y=function(d,f){if(d.type=="text"&&!!(f[b]("text")||f[b]("font")||f[b]("font-size")||f[b]("x")||f[b]("y"))){var g=d.attrs,h=d.node,i=h.firstChild?e(a._g.doc.defaultView.getComputedStyle(h.firstChild,l).getPropertyValue("font-size"),10):10;if(f[b]("text")){g.text=f.text;while(h.firstChild)h.removeChild(h.firstChild);var j=c(f.text).split("\n"),k=[],m;for(var n=0,o=j.length;n<o;n++)m=q("tspan"),n&&q(m,{dy:i*x,x:g.x}),m.appendChild(a._g.doc.createTextNode(j[n])),h.appendChild(m),k[n]=m}else{k=h.getElementsByTagName("tspan");for(n=0,o=k.length;n<o;n++)n?q(k[n],{dy:i*x,x:g.x}):q(k[0],{dy:0})}q(h,{x:g.x,y:g.y}),d._.dirty=1;var p=d._getBBox(),r=g.y-(p.y+p.height/2);r&&a.is(r,"finite")&&q(k[0],{dy:r})}},z=function(b,c){var d=0,e=0;this[0]=this.node=b,b.raphael=!0,this.id=a._oid++,b.raphaelid=this.id,this.matrix=a.matrix(),this.realPath=null,this.paper=c,this.attrs=this.attrs||{},this._={transform:[],sx:1,sy:1,deg:0,dx:0,dy:0,dirty:1},!c.bottom&&(c.bottom=this),this.prev=c.top,c.top&&(c.top.next=this),c.top=this,this.next=null},A=a.el;z.prototype=A,A.constructor=z,a._engine.path=function(a,b){var c=q("path");b.canvas&&b.canvas.appendChild(c);var d=new z(c,b);d.type="path",w(d,{fill:"none",stroke:"#000",path:a});return d},A.rotate=function(a,b,e){if(this.removed)return this;a=c(a).split(j),a.length-1&&(b=d(a[1]),e=d(a[2])),a=d(a[0]),e==null&&(b=e);if(b==null||e==null){var f=this.getBBox(1);b=f.x+f.width/2,e=f.y+f.height/2}this.transform(this._.transform.concat([["r",a,b,e]]));return this},A.scale=function(a,b,e,f){if(this.removed)return this;a=c(a).split(j),a.length-1&&(b=d(a[1]),e=d(a[2]),f=d(a[3])),a=d(a[0]),b==null&&(b=a),f==null&&(e=f);if(e==null||f==null)var g=this.getBBox(1);e=e==null?g.x+g.width/2:e,f=f==null?g.y+g.height/2:f,this.transform(this._.transform.concat([["s",a,b,e,f]]));return this},A.translate=function(a,b){if(this.removed)return this;a=c(a).split(j),a.length-1&&(b=d(a[1])),a=d(a[0])||0,b=+b||0,this.transform(this._.transform.concat([["t",a,b]]));return this},A.transform=function(c){var d=this._;if(c==null)return d.transform;a._extractTransform(this,c),this.clip&&q(this.clip,{transform:this.matrix.invert()}),this.pattern&&s(this),this.node&&q(this.node,{transform:this.matrix});if(d.sx!=1||d.sy!=1){var e=this.attrs[b]("stroke-width")?this.attrs["stroke-width"]:1;this.attr({"stroke-width":e})}return this},A.hide=function(){!this.removed&&this.paper.safari(this.node.style.display="none");return this},A.show=function(){!this.removed&&this.paper.safari(this.node.style.display="");return this},A.remove=function(){if(!this.removed&&!!this.node.parentNode){var b=this.paper;b.__set__&&b.__set__.exclude(this),k.unbind("raphael.*.*."+this.id),this.gradient&&b.defs.removeChild(this.gradient),a._tear(this,b),this.node.parentNode.tagName.toLowerCase()=="a"?this.node.parentNode.parentNode.removeChild(this.node.parentNode):this.node.parentNode.removeChild(this.node);for(var c in this)this[c]=typeof this[c]=="function"?a._removedFactory(c):null;this.removed=!0}},A._getBBox=function(){if(this.node.style.display=="none"){this.show();var a=!0}var b={};try{b=this.node.getBBox()}catch(c){}finally{b=b||{}}a&&this.hide();return b},A.attr=function(c,d){if(this.removed)return this;if(c==null){var e={};for(var f in this.attrs)this.attrs[b](f)&&(e[f]=this.attrs[f]);e.gradient&&e.fill=="none"&&(e.fill=e.gradient)&&delete e.gradient,e.transform=this._.transform;return e}if(d==null&&a.is(c,"string")){if(c=="fill"&&this.attrs.fill=="none"&&this.attrs.gradient)return this.attrs.gradient;if(c=="transform")return this._.transform;var g=c.split(j),h={};for(var i=0,l=g.length;i<l;i++)c=g[i],c in this.attrs?h[c]=this.attrs[c]:a.is(this.paper.customAttributes[c],"function")?h[c]=this.paper.customAttributes[c].def:h[c]=a._availableAttrs[c];return l-1?h:h[g[0]]}if(d==null&&a.is(c,"array")){h={};for(i=0,l=c.length;i<l;i++)h[c[i]]=this.attr(c[i]);return h}if(d!=null){var m={};m[c]=d}else c!=null&&a.is(c,"object")&&(m=c);for(var n in m)k("raphael.attr."+n+"."+this.id,this,m[n]);for(n in this.paper.customAttributes)if(this.paper.customAttributes[b](n)&&m[b](n)&&a.is(this.paper.customAttributes[n],"function")){var o=this.paper.customAttributes[n].apply(this,[].concat(m[n]));this.attrs[n]=m[n];for(var p in o)o[b](p)&&(m[p]=o[p])}w(this,m);return this},A.toFront=function(){if(this.removed)return this;this.node.parentNode.tagName.toLowerCase()=="a"?this.node.parentNode.parentNode.appendChild(this.node.parentNode):this.node.parentNode.appendChild(this.node);var b=this.paper;b.top!=this&&a._tofront(this,b);return this},A.toBack=function(){if(this.removed)return this;var b=this.node.parentNode;b.tagName.toLowerCase()=="a"?b.parentNode.insertBefore(this.node.parentNode,this.node.parentNode.parentNode.firstChild):b.firstChild!=this.node&&b.insertBefore(this.node,this.node.parentNode.firstChild),a._toback(this,this.paper);var c=this.paper;return this},A.insertAfter=function(b){if(this.removed)return this;var c=b.node||b[b.length-1].node;c.nextSibling?c.parentNode.insertBefore(this.node,c.nextSibling):c.parentNode.appendChild(this.node),a._insertafter(this,b,this.paper);return this},A.insertBefore=function(b){if(this.removed)return this;var c=b.node||b[0].node;c.parentNode.insertBefore(this.node,c),a._insertbefore(this,b,this.paper);return this},A.blur=function(b){var c=this;if(+b!==0){var d=q("filter"),e=q("feGaussianBlur");c.attrs.blur=b,d.id=a.createUUID(),q(e,{stdDeviation:+b||1.5}),d.appendChild(e),c.paper.defs.appendChild(d),c._blur=d,q(c.node,{filter:"url(#"+d.id+")"})}else c._blur&&(c._blur.parentNode.removeChild(c._blur),delete c._blur,delete c.attrs.blur),c.node.removeAttribute("filter")},a._engine.circle=function(a,b,c,d){var e=q("circle");a.canvas&&a.canvas.appendChild(e);var f=new z(e,a);f.attrs={cx:b,cy:c,r:d,fill:"none",stroke:"#000"},f.type="circle",q(e,f.attrs);return f},a._engine.rect=function(a,b,c,d,e,f){var g=q("rect");a.canvas&&a.canvas.appendChild(g);var h=new z(g,a);h.attrs={x:b,y:c,width:d,height:e,r:f||0,rx:f||0,ry:f||0,fill:"none",stroke:"#000"},h.type="rect",q(g,h.attrs);return h},a._engine.ellipse=function(a,b,c,d,e){var f=q("ellipse");a.canvas&&a.canvas.appendChild(f);var g=new z(f,a);g.attrs={cx:b,cy:c,rx:d,ry:e,fill:"none",stroke:"#000"},g.type="ellipse",q(f,g.attrs);return g},a._engine.image=function(a,b,c,d,e,f){var g=q("image");q(g,{x:c,y:d,width:e,height:f,preserveAspectRatio:"none"}),g.setAttributeNS(n,"href",b),a.canvas&&a.canvas.appendChild(g);var h=new z(g,a);h.attrs={x:c,y:d,width:e,height:f,src:b},h.type="image";return h},a._engine.text=function(b,c,d,e){var f=q("text");b.canvas&&b.canvas.appendChild(f);var g=new z(f,b);g.attrs={x:c,y:d,"text-anchor":"middle",text:e,font:a._availableAttrs.font,stroke:"none",fill:"#000"},g.type="text",w(g,g.attrs);return g},a._engine.setSize=function(a,b){this.width=a||this.width,this.height=b||this.height,this.canvas.setAttribute("width",this.width),this.canvas.setAttribute("height",this.height),this._viewBox&&this.setViewBox.apply(this,this._viewBox);return this},a._engine.create=function(){var b=a._getContainer.apply(0,arguments),c=b&&b.container,d=b.x,e=b.y,f=b.width,g=b.height;if(!c)throw new Error("SVG container not found.");var h=q("svg"),i="overflow:hidden;",j;d=d||0,e=e||0,f=f||512,g=g||342,q(h,{height:g,version:1.1,width:f,xmlns:"http://www.w3.org/2000/svg"}),c==1?(h.style.cssText=i+"position:absolute;left:"+d+"px;top:"+e+"px",a._g.doc.body.appendChild(h),j=1):(h.style.cssText=i+"position:relative",c.firstChild?c.insertBefore(h,c.firstChild):c.appendChild(h)),c=new a._Paper,c.width=f,c.height=g,c.canvas=h,c.clear(),c._left=c._top=0,j&&(c.renderfix=function(){}),c.renderfix();return c},a._engine.setViewBox=function(a,b,c,d,e){k("raphael.setViewBox",this,this._viewBox,[a,b,c,d,e]);var f=g(c/this.width,d/this.height),h=this.top,i=e?"meet":"xMinYMin",j,l;a==null?(this._vbSize&&(f=1),delete this._vbSize,j="0 0 "+this.width+m+this.height):(this._vbSize=f,j=a+m+b+m+c+m+d),q(this.canvas,{viewBox:j,preserveAspectRatio:i});while(f&&h)l="stroke-width"in h.attrs?h.attrs["stroke-width"]:1,h.attr({"stroke-width":l}),h._.dirty=1,h._.dirtyT=1,h=h.prev;this._viewBox=[a,b,c,d,!!e];return this},a.prototype.renderfix=function(){var a=this.canvas,b=a.style,c;try{c=a.getScreenCTM()||a.createSVGMatrix()}catch(d){c=a.createSVGMatrix()}var e=-c.e%1,f=-c.f%1;if(e||f)e&&(this._left=(this._left+e)%1,b.left=this._left+"px"),f&&(this._top=(this._top+f)%1,b.top=this._top+"px")},a.prototype.clear=function(){a.eve("raphael.clear",this);var b=this.canvas;while(b.firstChild)b.removeChild(b.firstChild);this.bottom=this.top=null,(this.desc=q("desc")).appendChild(a._g.doc.createTextNode("Created with Raphaël "+a.version)),b.appendChild(this.desc),b.appendChild(this.defs=q("defs"))},a.prototype.remove=function(){k("raphael.remove",this),this.canvas.parentNode&&this.canvas.parentNode.removeChild(this.canvas);for(var b in this)this[b]=typeof this[b]=="function"?a._removedFactory(b):null};var B=a.st;for(var C in A)A[b](C)&&!B[b](C)&&(B[C]=function(a){return function(){var b=arguments;return this.forEach(function(c){c[a].apply(c,b)})}}(C))}(window.Raphael),window.Raphael.vml&&function(a){var b="hasOwnProperty",c=String,d=parseFloat,e=Math,f=e.round,g=e.max,h=e.min,i=e.abs,j="fill",k=/[, ]+/,l=a.eve,m=" progid:DXImageTransform.Microsoft",n=" ",o="",p={M:"m",L:"l",C:"c",Z:"x",m:"t",l:"r",c:"v",z:"x"},q=/([clmz]),?([^clmz]*)/gi,r=/ progid:\S+Blur\([^\)]+\)/g,s=/-?[^,\s-]+/g,t="position:absolute;left:0;top:0;width:1px;height:1px",u=21600,v={path:1,rect:1,image:1},w={circle:1,ellipse:1},x=function(b){var d=/[ahqstv]/ig,e=a._pathToAbsolute;c(b).match(d)&&(e=a._path2curve),d=/[clmz]/g;if(e==a._pathToAbsolute&&!c(b).match(d)){var g=c(b).replace(q,function(a,b,c){var d=[],e=b.toLowerCase()=="m",g=p[b];c.replace(s,function(a){e&&d.length==2&&(g+=d+p[b=="m"?"l":"L"],d=[]),d.push(f(a*u))});return g+d});return g}var h=e(b),i,j;g=[];for(var k=0,l=h.length;k<l;k++){i=h[k],j=h[k][0].toLowerCase(),j=="z"&&(j="x");for(var m=1,r=i.length;m<r;m++)j+=f(i[m]*u)+(m!=r-1?",":o);g.push(j)}return g.join(n)},y=function(b,c,d){var e=a.matrix();e.rotate(-b,.5,.5);return{dx:e.x(c,d),dy:e.y(c,d)}},z=function(a,b,c,d,e,f){var g=a._,h=a.matrix,k=g.fillpos,l=a.node,m=l.style,o=1,p="",q,r=u/b,s=u/c;m.visibility="hidden";if(!!b&&!!c){l.coordsize=i(r)+n+i(s),m.rotation=f*(b*c<0?-1:1);if(f){var t=y(f,d,e);d=t.dx,e=t.dy}b<0&&(p+="x"),c<0&&(p+=" y")&&(o=-1),m.flip=p,l.coordorigin=d*-r+n+e*-s;if(k||g.fillsize){var v=l.getElementsByTagName(j);v=v&&v[0],l.removeChild(v),k&&(t=y(f,h.x(k[0],k[1]),h.y(k[0],k[1])),v.position=t.dx*o+n+t.dy*o),g.fillsize&&(v.size=g.fillsize[0]*i(b)+n+g.fillsize[1]*i(c)),l.appendChild(v)}m.visibility="visible"}};a.toString=function(){return"Your browser doesn’t support SVG. Falling down to VML.\nYou are running Raphaël "+this.version};var A=function(a,b,d){var e=c(b).toLowerCase().split("-"),f=d?"end":"start",g=e.length,h="classic",i="medium",j="medium";while(g--)switch(e[g]){case"block":case"classic":case"oval":case"diamond":case"open":case"none":h=e[g];break;case"wide":case"narrow":j=e[g];break;case"long":case"short":i=e[g]}var k=a.node.getElementsByTagName("stroke")[0];k[f+"arrow"]=h,k[f+"arrowlength"]=i,k[f+"arrowwidth"]=j},B=function(e,i){e.attrs=e.attrs||{};var l=e.node,m=e.attrs,p=l.style,q,r=v[e.type]&&(i.x!=m.x||i.y!=m.y||i.width!=m.width||i.height!=m.height||i.cx!=m.cx||i.cy!=m.cy||i.rx!=m.rx||i.ry!=m.ry||i.r!=m.r),s=w[e.type]&&(m.cx!=i.cx||m.cy!=i.cy||m.r!=i.r||m.rx!=i.rx||m.ry!=i.ry),t=e;for(var y in i)i[b](y)&&(m[y]=i[y]);r&&(m.path=a._getPath[e.type](e),e._.dirty=1),i.href&&(l.href=i.href),i.title&&(l.title=i.title),i.target&&(l.target=i.target),i.cursor&&(p.cursor=i.cursor),"blur"in i&&e.blur(i.blur);if(i.path&&e.type=="path"||r)l.path=x(~c(m.path).toLowerCase().indexOf("r")?a._pathToAbsolute(m.path):m.path),e.type=="image"&&(e._.fillpos=[m.x,m.y],e._.fillsize=[m.width,m.height],z(e,1,1,0,0,0));"transform"in i&&e.transform(i.transform);if(s){var B=+m.cx,D=+m.cy,E=+m.rx||+m.r||0,G=+m.ry||+m.r||0;l.path=a.format("ar{0},{1},{2},{3},{4},{1},{4},{1}x",f((B-E)*u),f((D-G)*u),f((B+E)*u),f((D+G)*u),f(B*u))}if("clip-rect"in i){var H=c(i["clip-rect"]).split(k);if(H.length==4){H[2]=+H[2]+ +H[0],H[3]=+H[3]+ +H[1];var I=l.clipRect||a._g.doc.createElement("div"),J=I.style;J.clip=a.format("rect({1}px {2}px {3}px {0}px)",H),l.clipRect||(J.position="absolute",J.top=0,J.left=0,J.width=e.paper.width+"px",J.height=e.paper.height+"px",l.parentNode.insertBefore(I,l),I.appendChild(l),l.clipRect=I)}i["clip-rect"]||l.clipRect&&(l.clipRect.style.clip="auto")}if(e.textpath){var K=e.textpath.style;i.font&&(K.font=i.font),i["font-family"]&&(K.fontFamily='"'+i["font-family"].split(",")[0].replace(/^['"]+|['"]+$/g,o)+'"'),i["font-size"]&&(K.fontSize=i["font-size"]),i["font-weight"]&&(K.fontWeight=i["font-weight"]),i["font-style"]&&(K.fontStyle=i["font-style"])}"arrow-start"in i&&A(t,i["arrow-start"]),"arrow-end"in i&&A(t,i["arrow-end"],1);if(i.opacity!=null||i["stroke-width"]!=null||i.fill!=null||i.src!=null||i.stroke!=null||i["stroke-width"]!=null||i["stroke-opacity"]!=null||i["fill-opacity"]!=null||i["stroke-dasharray"]!=null||i["stroke-miterlimit"]!=null||i["stroke-linejoin"]!=null||i["stroke-linecap"]!=null){var L=l.getElementsByTagName(j),M=!1;L=L&&L[0],!L&&(M=L=F(j)),e.type=="image"&&i.src&&(L.src=i.src),i.fill&&(L.on=!0);if(L.on==null||i.fill=="none"||i.fill===null)L.on=!1;if(L.on&&i.fill){var N=c(i.fill).match(a._ISURL);if(N){L.parentNode==l&&l.removeChild(L),L.rotate=!0,L.src=N[1],L.type="tile";var O=e.getBBox(1);L.position=O.x+n+O.y,e._.fillpos=[O.x,O.y],a._preload(N[1],function(){e._.fillsize=[this.offsetWidth,this.offsetHeight]})}else L.color=a.getRGB(i.fill).hex,L.src=o,L.type="solid",a.getRGB(i.fill).error&&(t.type in{circle:1,ellipse:1}||c(i.fill).charAt()!="r")&&C(t,i.fill,L)&&(m.fill="none",m.gradient=i.fill,L.rotate=!1)}if("fill-opacity"in i||"opacity"in i){var P=((+m["fill-opacity"]+1||2)-1)*((+m.opacity+1||2)-1)*((+a.getRGB(i.fill).o+1||2)-1);P=h(g(P,0),1),L.opacity=P,L.src&&(L.color="none")}l.appendChild(L);var Q=l.getElementsByTagName("stroke")&&l.getElementsByTagName("stroke")[0],T=!1;!Q&&(T=Q=F("stroke"));if(i.stroke&&i.stroke!="none"||i["stroke-width"]||i["stroke-opacity"]!=null||i["stroke-dasharray"]||i["stroke-miterlimit"]||i["stroke-linejoin"]||i["stroke-linecap"])Q.on=!0;(i.stroke=="none"||i.stroke===null||Q.on==null||i.stroke==0||i["stroke-width"]==0)&&(Q.on=!1);var U=a.getRGB(i.stroke);Q.on&&i.stroke&&(Q.color=U.hex),P=((+m["stroke-opacity"]+1||2)-1)*((+m.opacity+1||2)-1)*((+U.o+1||2)-1);var V=(d(i["stroke-width"])||1)*.75;P=h(g(P,0),1),i["stroke-width"]==null&&(V=m["stroke-width"]),i["stroke-width"]&&(Q.weight=V),V&&V<1&&(P*=V)&&(Q.weight=1),Q.opacity=P,i["stroke-linejoin"]&&(Q.joinstyle=i["stroke-linejoin"]||"miter"),Q.miterlimit=i["stroke-miterlimit"]||8,i["stroke-linecap"]&&(Q.endcap=i["stroke-linecap"]=="butt"?"flat":i["stroke-linecap"]=="square"?"square":"round");if(i["stroke-dasharray"]){var W={"-":"shortdash",".":"shortdot","-.":"shortdashdot","-..":"shortdashdotdot",". ":"dot","- ":"dash","--":"longdash","- .":"dashdot","--.":"longdashdot","--..":"longdashdotdot"};Q.dashstyle=W[b](i["stroke-dasharray"])?W[i["stroke-dasharray"]]:o}T&&l.appendChild(Q)}if(t.type=="text"){t.paper.canvas.style.display=o;var X=t.paper.span,Y=100,Z=m.font&&m.font.match(/\d+(?:\.\d*)?(?=px)/);p=X.style,m.font&&(p.font=m.font),m["font-family"]&&(p.fontFamily=m["font-family"]),m["font-weight"]&&(p.fontWeight=m["font-weight"]),m["font-style"]&&(p.fontStyle=m["font-style"]),Z=d(m["font-size"]||Z&&Z[0])||10,p.fontSize=Z*Y+"px",t.textpath.string&&(X.innerHTML=c(t.textpath.string).replace(/</g,"&#60;").replace(/&/g,"&#38;").replace(/\n/g,"<br>"));var $=X.getBoundingClientRect();t.W=m.w=($.right-$.left)/Y,t.H=m.h=($.bottom-$.top)/Y,t.X=m.x,t.Y=m.y+t.H/2,("x"in i||"y"in i)&&(t.path.v=a.format("m{0},{1}l{2},{1}",f(m.x*u),f(m.y*u),f(m.x*u)+1));var _=["x","y","text","font","font-family","font-weight","font-style","font-size"];for(var ba=0,bb=_.length;ba<bb;ba++)if(_[ba]in i){t._.dirty=1;break}switch(m["text-anchor"]){case"start":t.textpath.style["v-text-align"]="left",t.bbx=t.W/2;break;case"end":t.textpath.style["v-text-align"]="right",t.bbx=-t.W/2;break;default:t.textpath.style["v-text-align"]="center",t.bbx=0}t.textpath.style["v-text-kern"]=!0}},C=function(b,f,g){b.attrs=b.attrs||{};var h=b.attrs,i=Math.pow,j,k,l="linear",m=".5 .5";b.attrs.gradient=f,f=c(f).replace(a._radial_gradient,function(a,b,c){l="radial",b&&c&&(b=d(b),c=d(c),i(b-.5,2)+i(c-.5,2)>.25&&(c=e.sqrt(.25-i(b-.5,2))*((c>.5)*2-1)+.5),m=b+n+c);return o}),f=f.split(/\s*\-\s*/);if(l=="linear"){var p=f.shift();p=-d(p);if(isNaN(p))return null}var q=a._parseDots(f);if(!q)return null;b=b.shape||b.node;if(q.length){b.removeChild(g),g.on=!0,g.method="none",g.color=q[0].color,g.color2=q[q.length-1].color;var r=[];for(var s=0,t=q.length;s<t;s++)q[s].offset&&r.push(q[s].offset+n+q[s].color);g.colors=r.length?r.join():"0% "+g.color,l=="radial"?(g.type="gradientTitle",g.focus="100%",g.focussize="0 0",g.focusposition=m,g.angle=0):(g.type="gradient",g.angle=(270-p)%360),b.appendChild(g)}return 1},D=function(b,c){this[0]=this.node=b,b.raphael=!0,this.id=a._oid++,b.raphaelid=this.id,this.X=0,this.Y=0,this.attrs={},this.paper=c,this.matrix=a.matrix(),this._={transform:[],sx:1,sy:1,dx:0,dy:0,deg:0,dirty:1,dirtyT:1},!c.bottom&&(c.bottom=this),this.prev=c.top,c.top&&(c.top.next=this),c.top=this,this.next=null},E=a.el;D.prototype=E,E.constructor=D,E.transform=function(b){if(b==null)return this._.transform;var d=this.paper._viewBoxShift,e=d?"s"+[d.scale,d.scale]+"-1-1t"+[d.dx,d.dy]:o,f;d&&(f=b=c(b).replace(/\.{3}|\u2026/g,this._.transform||o)),a._extractTransform(this,e+b);var g=this.matrix.clone(),h=this.skew,i=this.node,j,k=~c(this.attrs.fill).indexOf("-"),l=!c(this.attrs.fill).indexOf("url(");g.translate(-0.5,-0.5);if(l||k||this.type=="image"){h.matrix="1 0 0 1",h.offset="0 0",j=g.split();if(k&&j.noRotation||!j.isSimple){i.style.filter=g.toFilter();var m=this.getBBox(),p=this.getBBox(1),q=m.x-p.x,r=m.y-p.y;i.coordorigin=q*-u+n+r*-u,z(this,1,1,q,r,0)}else i.style.filter=o,z(this,j.scalex,j.scaley,j.dx,j.dy,j.rotate)}else i.style.filter=o,h.matrix=c(g),h.offset=g.offset();f&&(this._.transform=f);return this},E.rotate=function(a,b,e){if(this.removed)return this;if(a!=null){a=c(a).split(k),a.length-1&&(b=d(a[1]),e=d(a[2])),a=d(a[0]),e==null&&(b=e);if(b==null||e==null){var f=this.getBBox(1);b=f.x+f.width/2,e=f.y+f.height/2}this._.dirtyT=1,this.transform(this._.transform.concat([["r",a,b,e]]));return this}},E.translate=function(a,b){if(this.removed)return this;a=c(a).split(k),a.length-1&&(b=d(a[1])),a=d(a[0])||0,b=+b||0,this._.bbox&&(this._.bbox.x+=a,this._.bbox.y+=b),this.transform(this._.transform.concat([["t",a,b]]));return this},E.scale=function(a,b,e,f){if(this.removed)return this;a=c(a).split(k),a.length-1&&(b=d(a[1]),e=d(a[2]),f=d(a[3]),isNaN(e)&&(e=null),isNaN(f)&&(f=null)),a=d(a[0]),b==null&&(b=a),f==null&&(e=f);if(e==null||f==null)var g=this.getBBox(1);e=e==null?g.x+g.width/2:e,f=f==null?g.y+g.height/2:f,this.transform(this._.transform.concat([["s",a,b,e,f]])),this._.dirtyT=1;return this},E.hide=function(){!this.removed&&(this.node.style.display="none");return this},E.show=function(){!this.removed&&(this.node.style.display=o);return this},E._getBBox=function(){if(this.removed)return{};return{x:this.X+(this.bbx||0)-this.W/2,y:this.Y-this.H,width:this.W,height:this.H}},E.remove=function(){if(!this.removed&&!!this.node.parentNode){this.paper.__set__&&this.paper.__set__.exclude(this),a.eve.unbind("raphael.*.*."+this.id),a._tear(this,this.paper),this.node.parentNode.removeChild(this.node),this.shape&&this.shape.parentNode.removeChild(this.shape);for(var b in this)this[b]=typeof this[b]=="function"?a._removedFactory(b):null;this.removed=!0}},E.attr=function(c,d){if(this.removed)return this;if(c==null){var e={};for(var f in this.attrs)this.attrs[b](f)&&(e[f]=this.attrs[f]);e.gradient&&e.fill=="none"&&(e.fill=e.gradient)&&delete e.gradient,e.transform=this._.transform;return e}if(d==null&&a.is(c,"string")){if(c==j&&this.attrs.fill=="none"&&this.attrs.gradient)return this.attrs.gradient;var g=c.split(k),h={};for(var i=0,m=g.length;i<m;i++)c=g[i],c in this.attrs?h[c]=this.attrs[c]:a.is(this.paper.customAttributes[c],"function")?h[c]=this.paper.customAttributes[c].def:h[c]=a._availableAttrs[c];return m-1?h:h[g[0]]}if(this.attrs&&d==null&&a.is(c,"array")){h={};for(i=0,m=c.length;i<m;i++)h[c[i]]=this.attr(c[i]);return h}var n;d!=null&&(n={},n[c]=d),d==null&&a.is(c,"object")&&(n=c);for(var o in n)l("raphael.attr."+o+"."+this.id,this,n[o]);if(n){for(o in this.paper.customAttributes)if(this.paper.customAttributes[b](o)&&n[b](o)&&a.is(this.paper.customAttributes[o],"function")){var p=this.paper.customAttributes[o].apply(this,[].concat(n[o]));this.attrs[o]=n[o];for(var q in p)p[b](q)&&(n[q]=p[q])}n.text&&this.type=="text"&&(this.textpath.string=n.text),B(this,n)}return this},E.toFront=function(){!this.removed&&this.node.parentNode.appendChild(this.node),this.paper&&this.paper.top!=this&&a._tofront(this,this.paper);return this},E.toBack=function(){if(this.removed)return this;this.node.parentNode.firstChild!=this.node&&(this.node.parentNode.insertBefore(this.node,this.node.parentNode.firstChild),a._toback(this,this.paper));return this},E.insertAfter=function(b){if(this.removed)return this;b.constructor==a.st.constructor&&(b=b[b.length-1]),b.node.nextSibling?b.node.parentNode.insertBefore(this.node,b.node.nextSibling):b.node.parentNode.appendChild(this.node),a._insertafter(this,b,this.paper);return this},E.insertBefore=function(b){if(this.removed)return this;b.constructor==a.st.constructor&&(b=b[0]),b.node.parentNode.insertBefore(this.node,b.node),a._insertbefore(this,b,this.paper);return this},E.blur=function(b){var c=this.node.runtimeStyle,d=c.filter;d=d.replace(r,o),+b!==0?(this.attrs.blur=b,c.filter=d+n+m+".Blur(pixelradius="+(+b||1.5)+")",c.margin=a.format("-{0}px 0 0 -{0}px",f(+b||1.5))):(c.filter=d,c.margin=0,delete this.attrs.blur)},a._engine.path=function(a,b){var c=F("shape");c.style.cssText=t,c.coordsize=u+n+u,c.coordorigin=b.coordorigin;var d=new D(c,b),e={fill:"none",stroke:"#000"};a&&(e.path=a),d.type="path",d.path=[],d.Path=o,B(d,e),b.canvas.appendChild(c);var f=F("skew");f.on=!0,c.appendChild(f),d.skew=f,d.transform(o);return d},a._engine.rect=function(b,c,d,e,f,g){var h=a._rectPath(c,d,e,f,g),i=b.path(h),j=i.attrs;i.X=j.x=c,i.Y=j.y=d,i.W=j.width=e,i.H=j.height=f,j.r=g,j.path=h,i.type="rect";return i},a._engine.ellipse=function(a,b,c,d,e){var f=a.path(),g=f.attrs;f.X=b-d,f.Y=c-e,f.W=d*2,f.H=e*2,f.type="ellipse",B(f,{cx:b,cy:c,rx:d,ry:e});return f},a._engine.circle=function(a,b,c,d){var e=a.path(),f=e.attrs;e.X=b-d,e.Y=c-d,e.W=e.H=d*2,e.type="circle",B(e,{cx:b,cy:c,r:d});return e},a._engine.image=function(b,c,d,e,f,g){var h=a._rectPath(d,e,f,g),i=b.path(h).attr({stroke:"none"}),k=i.attrs,l=i.node,m=l.getElementsByTagName(j)[0];k.src=c,i.X=k.x=d,i.Y=k.y=e,i.W=k.width=f,i.H=k.height=g,k.path=h,i.type="image",m.parentNode==l&&l.removeChild(m),m.rotate=!0,m.src=c,m.type="tile",i._.fillpos=[d,e],i._.fillsize=[f,g],l.appendChild(m),z(i,1,1,0,0,0);return i},a._engine.text=function(b,d,e,g){var h=F("shape"),i=F("path"),j=F("textpath");d=d||0,e=e||0,g=g||"",i.v=a.format("m{0},{1}l{2},{1}",f(d*u),f(e*u),f(d*u)+1),i.textpathok=!0,j.string=c(g),j.on=!0,h.style.cssText=t,h.coordsize=u+n+u,h.coordorigin="0 0";var k=new D(h,b),l={fill:"#000",stroke:"none",font:a._availableAttrs.font,text:g};k.shape=h,k.path=i,k.textpath=j,k.type="text",k.attrs.text=c(g),k.attrs.x=d,k.attrs.y=e,k.attrs.w=1,k.attrs.h=1,B(k,l),h.appendChild(j),h.appendChild(i),b.canvas.appendChild(h);var m=F("skew");m.on=!0,h.appendChild(m),k.skew=m,k.transform(o);return k},a._engine.setSize=function(b,c){var d=this.canvas.style;this.width=b,this.height=c,b==+b&&(b+="px"),c==+c&&(c+="px"),d.width=b,d.height=c,d.clip="rect(0 "+b+" "+c+" 0)",this._viewBox&&a._engine.setViewBox.apply(this,this._viewBox);return this},a._engine.setViewBox=function(b,c,d,e,f){a.eve("raphael.setViewBox",this,this._viewBox,[b,c,d,e,f]);var h=this.width,i=this.height,j=1/g(d/h,e/i),k,l;f&&(k=i/e,l=h/d,d*k<h&&(b-=(h-d*k)/2/k),e*l<i&&(c-=(i-e*l)/2/l)),this._viewBox=[b,c,d,e,!!f],this._viewBoxShift={dx:-b,dy:-c,scale:j},this.forEach(function(a){a.transform("...")});return this};var F;a._engine.initWin=function(a){var b=a.document;b.createStyleSheet().addRule(".rvml","behavior:url(#default#VML)");try{!b.namespaces.rvml&&b.namespaces.add("rvml","urn:schemas-microsoft-com:vml"),F=function(a){return b.createElement("<rvml:"+a+' class="rvml">')}}catch(c){F=function(a){return b.createElement("<"+a+' xmlns="urn:schemas-microsoft.com:vml" class="rvml">')}}},a._engine.initWin(a._g.win),a._engine.create=function(){var b=a._getContainer.apply(0,arguments),c=b.container,d=b.height,e,f=b.width,g=b.x,h=b.y;if(!c)throw new Error("VML container not found.");var i=new a._Paper,j=i.canvas=a._g.doc.createElement("div"),k=j.style;g=g||0,h=h||0,f=f||512,d=d||342,i.width=f,i.height=d,f==+f&&(f+="px"),d==+d&&(d+="px"),i.coordsize=u*1e3+n+u*1e3,i.coordorigin="0 0",i.span=a._g.doc.createElement("span"),i.span.style.cssText="position:absolute;left:-9999em;top:-9999em;padding:0;margin:0;line-height:1;",j.appendChild(i.span),k.cssText=a.format("top:0;left:0;width:{0};height:{1};display:inline-block;position:relative;clip:rect(0 {0} {1} 0);overflow:hidden",f,d),c==1?(a._g.doc.body.appendChild(j),k.left=g+"px",k.top=h+"px",k.position="absolute"):c.firstChild?c.insertBefore(j,c.firstChild):c.appendChild(j),i.renderfix=function(){};return i},a.prototype.clear=function(){a.eve("raphael.clear",this),this.canvas.innerHTML=o,this.span=a._g.doc.createElement("span"),this.span.style.cssText="position:absolute;left:-9999em;top:-9999em;padding:0;margin:0;line-height:1;display:inline;",this.canvas.appendChild(this.span),this.bottom=this.top=null},a.prototype.remove=function(){a.eve("raphael.remove",this),this.canvas.parentNode.removeChild(this.canvas);for(var b in this)this[b]=typeof this[b]=="function"?a._removedFactory(b):null;return!0};var G=a.st;for(var H in E)E[b](H)&&!G[b](H)&&(G[H]=function(a){return function(){var b=arguments;return this.forEach(function(c){c[a].apply(c,b)})}}(H))}(window.Raphael);